- 网络安全的相关比赛有哪些?需要掌握哪些必备技能?
网安学习
web安全安全网络安全的相关比赛有哪
01、CTF(夺旗赛)这是一种最常见的网络安全竞技形式,要求参赛者在限定时间内解决一系列涉及密码学、逆向工程、漏洞利用、取证分析等领域的挑战,获取标志(flag)并提交得分。通过举办CTF来培养网络安全人才,已经发展成为了国际网络安全圈的共识。CTF赛事可以分为线上赛和线下赛,线上赛通常是解题模式(Jeopardy),线下赛通常是攻防模式(Attack-Defense)。CTF赛事的代表性线下赛事
- react native和java_Expo和React Native有什么区别?
weixin_39860166
reactnative和java
BrentVatne的答案很好,但我想补充一些细节.Expo扩展了ReactNative的API表面ReactNative没有提供开箱即用的所有JSAPI,只提供了大多数原始功能.ReactNative开发人员应该使用AndroidStudio/XCode链接其他本机库.Expo旨在增强RN并提供您最常见需求所需的所有JSAPI.它基本上是一组定义良好的原始库,已经为您打包在一个库中:ExpoKi
- Expo创建的React Native项目如何在Windows上进行打包
小童不学前端
ReactNatviereactnativeExpo
文章目录前言eas打包步骤什么是AAB转换为apk文件本地打包以Windows为例先安装docker,然后手动创建下面的三个文件构建前言下面是Expo如何在本地进行打包的过程(windows)eas打包如果使用云打包,花费时间较多,时间不固定,我自己差不多10分钟,但是很简单,问题较少步骤//1.登录easlogin//2.eas打包easbuild-pandroid//3.然后就是漫长的等待终端
- webview无法加载http流量及Expo修改Android权限
小童不学前端
ReactNatviereactnativeExpoandroidhttp
文章目录前言react-native-webview无法加载http流量报错修改http网络权限1.迁移到EASBuild2.创建android文件夹3.修改AndroidManifest.xml4.添加网络安全配置文件(可选)5.构建项目6.使用HTTPS前言在使用RN直接创建项目时,我们可以进行修改里面的一些权限,但是当我们使用Expo开发时,却发现没有android的这些文件夹,所以修改权限
- EXPO 结合 Alova请求库 快速搭建ReactNative开发平台
番茄小酱001
ReactNativeAlovareactnativereact.jsjavascript
alova是一个轻量级的请求策略库,目标是让接口的管理和使用变得非常简单。1、安装npminstallalova--save2、使用useRequest发送一个请求import{useRequest}from'alova'const{send:followAuthor}=useRequest((wtNo,status)=>follow({wtNo,status}),{immediate:false
- 通过RN框架实现跳转到微信落地页
番茄小酱001
ReactNativereactnativereact.jsjavascript
在使用Expo搭建的ReactNative应用中,要实现分享到微信后点击分享链接进入指定落地页,需要做如下几个步骤:1.**创建分享链接**:当用户点击分享按钮时,生成一个特定的分享链接,该链接应该包含信息用于标识用户点击的是哪个内容或页面。2.**设置落地页**:确保你有一个可以处理这个分享链接的落地页或路由。当用户点击链接时,应用能够识别并导航到相应的页面。3.**获取分享链接**:使用Exp
- Expo Router + Supabase使用流程
懒编程-二两
unsetunset前言unsetunsetExpo是一个React-native生态中的一个工具包,提供了非常多的功能,ExpoRouter是Expo最近推出的功能,其效果类似于Nextjs的router,可以基于目录结构来实现路由。Supabase是一个开源的postgres数据库,还带有用户体系功能,可以快速实现login、register这些功能。我将记录一下,我使用这2个工具,构建基础基
- 外汇天眼:2024香港Wiki Finance EXPO即将启航,世界顶级监管将坐镇现场
WAIHUI_tianyan
区块链人工智能大数据金融业界资讯
香港,作为国际金融中心的代表之一,一直以其独特的地理位置、健全的法律制度和开放的市场环境吸引着全球金融界的目光,WikiFinanceEXPO作为全球领先的金融展览和金融科技平台,不仅吸引了众多金融机构、投资者和金融科技企业的参与,更得到了全球金融监管机构的高度关注。而今天,WikiFX作为WikiFinanceEXPO的组织者,很荣幸地向各大家宣布,WikiFinanceEXPO将于2024年5
- Vue子组件调用父组件的方法
John的WEB前端学习日记
VueJS
Vue中子组件调用父组件的方法,这里有三种方法提供参考第一种方法是直接在子组件中通过this.$parent.event来调用父组件的方法父组件importchildfrom'~/components/dam/child';exportdefault{components:{child},methods:{fatherMethod(){console.log('测试');}}};子组件点击expo
- uniapp的api用法大全
前端fighter
uni-app前端javascript
页面生命周期APIuniApp中的页面生命周期API可以帮助开发者在页面的不同生命周期中执行相应的操作。常用的页面生命周期API包括:onLoad、onShow、onReady、onHide、onUnload等。其中,onLoad在页面加载时触发,onShow在页面显示时触发,onReady在页面初次渲染完成时触发,onHide在页面隐藏时触发,onUnload在页面卸载时触发。使用示例:expo
- Taro开发注意点
习惯就好a
taro开发注意点:注意点原因如果要支持ReactNative端,必须采用Flex布局,并且样式选择器仅支持类选择器,且不支持组合器TaroRN端是基于Expo,因此不支持引入ReactNative的第三方库某些样式代码仅供H5端使用,放在/*postcss-pxtransformrnejectenable*/与/*postcss-pxtransformrnejectdisable*/中间;在编译
- uniapp的api用法大全
前端fighter
uni-app前端javascript
页面生命周期APIuniApp中的页面生命周期API可以帮助开发者在页面的不同生命周期中执行相应的操作。常用的页面生命周期API包括:onLoad、onShow、onReady、onHide、onUnload等。其中,onLoad在页面加载时触发,onShow在页面显示时触发,onReady在页面初次渲染完成时触发,onHide在页面隐藏时触发,onUnload在页面卸载时触发。使用示例:expo
- docker - 常用命令详解
小柴林
Docker
本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来。根据自己的理解,总的来说分为以下几种:容器生命周期管理—docker[run|start|stop|restart|kill|rm|pause|unpause]容器操作运维—docker[ps|inspect|top|attach|events|logs|wait|expo
- expo 初始化指定SDK版本项目
he_wen_jian
ReactNative
expoinitmy-project--templateexpo-template-blank@sdk-44
- vuex的辅助函数
丁先生_b64b
https://www.cnblogs.com/samve/p/10726629.htmlvue:vuex中mapState、mapGetters、mapActions辅助函数及Module的使用vue提供了注入机制,就是把我们的store对象注入到根实例中。vue的根实例就是newVue构造函数,然后在所有的子组件中this.$store来指向store对象。在index.js中,我们用expo
- 10-内置事件和组件自定义事件
荆承鹏
1.介绍@click,keyup,keydown,update等这些都是js内置的事件,可以直接用。自定义事件是给组件用的。2.子向父组件传值的方法-->3.代码父级组件app自定义组件事件-->//import引入所有组件importStudentfrom'./components/Student.vue'importSchoolfrom'./components/School.vue'expo
- expo sdk 34.0.0.0 is not a valid sdk
younglaker
ExpoSDK34isnowavailableexpo更新后,sdk变为34手动降级为33:app.json"sdkVersion":"34.0.0",改为"sdkVersion":"33.0.0",package.json"react-native":"https://github.com/expo/react-native/archive/sdk-34.0.0.tar.gz",改为"react
- 认识与学习bash
lvhuiyin
linuxbashshell
1.认识BASH这个Shell1.1硬件、核心与Shell1.2为何要学文字接口的shell1.3系统的合法shell与/etc/shells功能1.4Bashshell的功能1.5Bashshell的内建命令:type1.6命令的下达2.Shell的变量功能2.1什么是变量?2.2变量的取用与配置:echo,变量配置守则,unset2.3环境变量的功能:env与常见环境变量说明,set,expo
- Webpack5入门到原理12:处理 Html 资源
duansamve
webpackwebpack
1.下载包npmihtml-webpack-plugin-D2.配置webpack.config.jsconstpath=require("path");constESLintWebpackPlugin=require("eslint-webpack-plugin");constHtmlWebpackPlugin=require("html-webpack-plugin");module.expo
- VUE3,自定义控制keep-alive缓存
日积一步
vue.jsjavascript前端
安装插件npminstallvite-plugin-vue-setup-extend--save在vite.config.ts中importVueSetupExtendfrom'vite-plugin-vue-setup-extend'.....plugins:[vue(),VueSetupExtend(),.....]useKeepalive.tsimport{ref}from"vue"expo
- React Native expo框架中报错error: TypeError: relativePosixPath.replaceAll is not a function
Charonmomo
移动端移动端reactnativeExpo
问题在Expo框架中遇到TypeError:relativePosixPath.replaceAllisnotafunction这样的错误通常是因为你正在使用的JavaScript环境中不支持String.prototype.replaceAll方法。replaceAll是一个相对较新的JavaScript方法,它在ES2020(即ECMAScript2020或ES11)中被引入。如果你遇到这个问
- Poi实现根据word模板导出-表格篇
1个凡夫俗子
POI系列javaword
往期系列传送门:Poi实现根据word模板导出-文本段落篇Poi实现根据word模板导出-图表篇(需要完整代码的直接看最后位置!!!)前言:word中表格数据填充是非常简单的,非常类似excel。如果你是从之前系列看过来的,应该能想到思路应该也是通过poi获取表格对象,然后通过表格对象操作里面的内容,套路都是一样的。话不多说,直接看代码吧,这部分很简单:@RequestMapping("/expo
- rn start
Jack おう
reactnativereact.jsjavascript
expoinitproject只有typescript文件才有提示导入提示->导入过的才有提示第一次导入不会有‘快速导入’找不到模块提示需要配置tsconfigaliassettinghttps://medium.com/@ruan.azevedo/typescript-path-alias-in-react-native-expo-without-babel-plugin-module-reso
- ElasticSearch使用Grafana监控服务状态-Docker版
jast_zsh
ElasticSearchelasticsearchgrafanadocker
文章目录版本信息构建`docker-compose.yml`参数说明创建Prometheus配置文件启动验证配置Grafana导入监控模板模板说明参考资料版本信息ElasticSearch:7.14.2elasticsearch_exporter:1.7.0(latest)下载地址:https://github.com/prometheus-community/elasticsearch_expo
- 对心理防御机制的认识及其在心理咨询与治疗中的意义与作用
邵真
齐帆齐微课在心理学中人们经常提到一个词叫心理防御机制。防御是自我为处理、控制导致内心矛盾与冲突而采取的一种心理保护措施。或者说心理防御是因焦虑而起,其功能是保护自我内心不受困扰。而内心的这种焦虑来源于三个方面:一是本能的张力;二是超我的压力;三是现实的危险。1894年弗洛伊德首次在其著作《ThePsychosesofdefense》中使用防御(defense)这个概念来描述自我(ego)对不愉快的
- Yarn安装:高效、可靠的包管理工具
虫小宝
Yarn安装
Yarn安装:高效、可靠的包管理工具大家好,我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天,让我们探讨一下在前端开发中极为常见的话题——“yarn安装”,并为你提供详细的安装指南。1.什么是Yarn?Yarn是由Facebook、Google、Expo和Tilde等公司联合推出的一款包管理工具,用于替代传统的npm(NodePackage
- 剑指offer-面试题11:数值的整数次方
Decorator2015
剑指offer面试题剑指offer
题目实现函数doublePower(doublebase,intexponent),求base的exponent次方,不得使用库函数,同时不需要考虑大数问题。分析代码中两处细节1,判断base是否等于0;2,用位运算符(%)来替代乘除法;3,求余运算。解doublePower(doublebase,intexponent){doubleresult;if(equal(base,0.0)&&expo
- fix react-native @expo problem with create-react-native-app
Wang's Blog
ReactReactNativereact-native
初始化项目时的问题$create-react-native-appAwesomeProject通过上面的命令出现下面的错误:[1/4]Resolvingpackages...warningreact-native-scripts>xdl>auth0>rest-facade>superagent-proxy>proxy-agent>socks-proxy-agent>
[email protected]:Ifu
- 【Vue】使用Axios请求下载后端返回的文件流,并能够提示后端报错信息
whu-水草
Vuevue.js前端javascript
【需求】使用Axios请求下载后端返回的文件流,下载失败时提示信息不写死,按照后端返回的信息进行提示。一、需求分析看到这个需求的时候,有人可能会很疑惑,这不是直接就能获取到吗,直接message.error()弹框就完事了,有什么问题。我们先来模拟一下,点击按钮下载文件,请求后端接口,后端返回文件流,前端通常会设置响应类型为blob,responseType:'blob',如://下载文件expo
- 在Mac系统下安装Apache Tomcat的详细步骤
乌龟车队长
tomcatapachemacosx
第一步:下载Tomcathttp://tomcat.apache.org左侧Download选择对应的版本,这里选择的是Tomcat9第二步:下载Tomcat下载后把文件移动到/usr/local/直接拉过去这是个隐藏文件点见finder(访达)点击前往-前往文件夹输入第三步:配置1.打开终端2.输入touch.bash_profile3.打开open-e.bash_profile4.输入expo
- 统一思想认识
永夜-极光
思想
1.统一思想认识的基础,才能有的放矢
原因:
总有一种描述事物的方式最贴近本质,最容易让人理解.
如何让教育更轻松,在于找到最适合学生的方式.
难点在于,如何模拟对方的思维基础选择合适的方式. &
- Joda Time使用笔记
bylijinnan
javajoda time
Joda Time的介绍可以参考这篇文章:
http://www.ibm.com/developerworks/cn/java/j-jodatime.html
工作中也常常用到Joda Time,为了避免每次使用都查API,记录一下常用的用法:
/**
* DateTime变化(增减)
*/
@Tes
- FileUtils API
eksliang
FileUtilsFileUtils API
转载请出自出处:http://eksliang.iteye.com/blog/2217374 一、概述
这是一个Java操作文件的常用库,是Apache对java的IO包的封装,这里面有两个非常核心的类FilenameUtils跟FileUtils,其中FilenameUtils是对文件名操作的封装;FileUtils是文件封装,开发中对文件的操作,几乎都可以在这个框架里面找到。 非常的好用。
- 各种新兴技术
不懂事的小屁孩
技术
1:gradle Gradle 是以 Groovy 语言为基础,面向Java应用为主。基于DSL(领域特定语言)语法的自动化构建工具。
现在构建系统常用到maven工具,现在有更容易上手的gradle,
搭建java环境:
http://www.ibm.com/developerworks/cn/opensource/os-cn-gradle/
搭建android环境:
http://m
- tomcat6的https双向认证
酷的飞上天空
tomcat6
1.生成服务器端证书
keytool -genkey -keyalg RSA -dname "cn=localhost,ou=sango,o=none,l=china,st=beijing,c=cn" -alias server -keypass password -keystore server.jks -storepass password -validity 36
- 托管虚拟桌面市场势不可挡
蓝儿唯美
用户还需要冗余的数据中心,dinCloud的高级副总裁兼首席营销官Ali Din指出。该公司转售一个MSP可以让用户登录并管理和提供服务的用于DaaS的云自动化控制台,提供服务或者MSP也可以自己来控制。
在某些情况下,MSP会在dinCloud的云服务上进行服务分层,如监控和补丁管理。
MSP的利润空间将根据其参与的程度而有所不同,Din说。
“我们有一些合作伙伴负责将我们推荐给客户作为个
- spring学习——xml文件的配置
a-john
spring
在Spring的学习中,对于其xml文件的配置是必不可少的。在Spring的多种装配Bean的方式中,采用XML配置也是最常见的。以下是一个简单的XML配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.or
- HDU 4342 History repeat itself 模拟
aijuans
模拟
来源:http://acm.hdu.edu.cn/showproblem.php?pid=4342
题意:首先让求第几个非平方数,然后求从1到该数之间的每个sqrt(i)的下取整的和。
思路:一个简单的模拟题目,但是由于数据范围大,需要用__int64。我们可以首先把平方数筛选出来,假如让求第n个非平方数的话,看n前面有多少个平方数,假设有x个,则第n个非平方数就是n+x。注意两种特殊情况,即
- java中最常用jar包的用途
asia007
java
java中最常用jar包的用途
jar包用途axis.jarSOAP引擎包commons-discovery-0.2.jar用来发现、查找和实现可插入式接口,提供一些一般类实例化、单件的生命周期管理的常用方法.jaxrpc.jarAxis运行所需要的组件包saaj.jar创建到端点的点到点连接的方法、创建并处理SOAP消息和附件的方法,以及接收和处理SOAP错误的方法. w
- ajax获取Struts框架中的json编码异常和Struts中的主控制器异常的解决办法
百合不是茶
jsjson编码返回异常
一:ajax获取自定义Struts框架中的json编码 出现以下 问题:
1,强制flush输出 json编码打印在首页
2, 不强制flush js会解析json 打印出来的是错误的jsp页面 却没有跳转到错误页面
3, ajax中的dataType的json 改为text 会
- JUnit使用的设计模式
bijian1013
java设计模式JUnit
JUnit源代码涉及使用了大量设计模式
1、模板方法模式(Template Method)
定义一个操作中的算法骨架,而将一些步骤延伸到子类中去,使得子类可以不改变一个算法的结构,即可重新定义该算法的某些特定步骤。这里需要复用的是算法的结构,也就是步骤,而步骤的实现可以在子类中完成。
 
- Linux常用命令(摘录)
sunjing
crondchkconfig
chkconfig --list 查看linux所有服务
chkconfig --add servicename 添加linux服务
netstat -apn | grep 8080 查看端口占用
env 查看所有环境变量
echo $JAVA_HOME 查看JAVA_HOME环境变量
安装编译器
yum install -y gcc
- 【Hadoop一】Hadoop伪集群环境搭建
bit1129
hadoop
结合网上多份文档,不断反复的修正hadoop启动和运行过程中出现的问题,终于把Hadoop2.5.2伪分布式安装起来,跑通了wordcount例子。Hadoop的安装复杂性的体现之一是,Hadoop的安装文档非常多,但是能一个文档走下来的少之又少,尤其是Hadoop不同版本的配置差异非常的大。Hadoop2.5.2于前两天发布,但是它的配置跟2.5.0,2.5.1没有分别。 &nb
- Anychart图表系列五之事件监听
白糖_
chart
创建图表事件监听非常简单:首先是通过addEventListener('监听类型',js监听方法)添加事件监听,然后在js监听方法中定义具体监听逻辑。
以钻取操作为例,当用户点击图表某一个point的时候弹出point的name和value,代码如下:
<script>
//创建AnyChart
var chart = new AnyChart();
//添加钻取操作&quo
- Web前端相关段子
braveCS
web前端
Web标准:结构、样式和行为分离
使用语义化标签
0)标签的语义:使用有良好语义的标签,能够很好地实现自我解释,方便搜索引擎理解网页结构,抓取重要内容。去样式后也会根据浏览器的默认样式很好的组织网页内容,具有很好的可读性,从而实现对特殊终端的兼容。
1)div和span是没有语义的:只是分别用作块级元素和行内元素的区域分隔符。当页面内标签无法满足设计需求时,才会适当添加div
- 编程之美-24点游戏
bylijinnan
编程之美
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Random;
import java.util.Set;
public class PointGame {
/**编程之美
- 主页面子页面传值总结
chengxuyuancsdn
总结
1、showModalDialog
returnValue是javascript中html的window对象的属性,目的是返回窗口值,当用window.showModalDialog函数打开一个IE的模式窗口时,用于返回窗口的值
主界面
var sonValue=window.showModalDialog("son.jsp");
子界面
window.retu
- [网络与经济]互联网+的含义
comsci
互联网+
互联网+后面是一个人的名字 = 网络控制系统
互联网+你的名字 = 网络个人数据库
每日提示:如果人觉得不舒服,千万不要外出到处走动,就呆在床上,玩玩手游,更不能够去开车,现在交通状况不
- oracle 创建视图 with check option
daizj
视图vieworalce
我们来看下面的例子:
create or replace view testview
as
select empno,ename from emp where ename like ‘M%’
with check option;
这里我们创建了一个视图,并使用了with check option来限制了视图。 然后我们来看一下视图包含的结果:
select * from testv
- ToastPlugin插件在cordova3.3下使用
dibov
Cordova
自己开发的Todos应用,想实现“
再按一次返回键退出程序 ”的功能,采用网上的ToastPlugins插件,发现代码或文章基本都是老版本,运行问题比较多。折腾了好久才弄好。下面吧基于cordova3.3下的ToastPlugins相关代码共享。
ToastPlugin.java
package&nbs
- C语言22个系统函数
dcj3sjt126com
cfunction
C语言系统函数一、数学函数下列函数存放在math.h头文件中Double floor(double num) 求出不大于num的最大数。Double fmod(x, y) 求整数x/y的余数。Double frexp(num, exp); double num; int *exp; 将num分为数字部分(尾数)x和 以2位的指数部分n,即num=x*2n,指数n存放在exp指向的变量中,返回x。D
- 开发一个类的流程
dcj3sjt126com
开发
本人近日根据自己的开发经验总结了一个类的开发流程。这个流程适用于单独开发的构件,并不适用于对一个项目中的系统对象开发。开发出的类可以存入私人类库,供以后复用。
以下是开发流程:
1. 明确类的功能,抽象出类的大概结构
2. 初步设想类的接口
3. 类名设计(驼峰式命名)
4. 属性设置(权限设置)
判断某些变量是否有必要作为成员属
- java 并发
shuizhaosi888
java 并发
能够写出高伸缩性的并发是一门艺术
在JAVA SE5中新增了3个包
java.util.concurrent
java.util.concurrent.atomic
java.util.concurrent.locks
在java的内存模型中,类的实例字段、静态字段和构成数组的对象元素都会被多个线程所共享,局部变量与方法参数都是线程私有的,不会被共享。
- Spring Security(11)——匿名认证
234390216
Spring SecurityROLE_ANNOYMOUS匿名
匿名认证
目录
1.1 配置
1.2 AuthenticationTrustResolver
对于匿名访问的用户,Spring Security支持为其建立一个匿名的AnonymousAuthenticat
- NODEJS项目实践0.2[ express,ajax通信...]
逐行分析JS源代码
Ajaxnodejsexpress
一、前言
通过上节学习,我们已经 ubuntu系统搭建了一个可以访问的nodejs系统,并做了nginx转发。本节原要做web端服务 及 mongodb的存取,但写着写着,web端就
- 在Struts2 的Action中怎样获取表单提交上来的多个checkbox的值
lhbthanks
javahtmlstrutscheckbox
第一种方法:获取结果String类型
在 Action 中获得的是一个 String 型数据,每一个被选中的 checkbox 的 value 被拼接在一起,每个值之间以逗号隔开(,)。
所以在 Action 中定义一个跟 checkbox 的 name 同名的属性来接收这些被选中的 checkbox 的 value 即可。
以下是实现的代码:
前台 HTML 代码:
- 003.Kafka基本概念
nweiren
hadoopkafka
Kafka基本概念:Topic、Partition、Message、Producer、Broker、Consumer。 Topic: 消息源(Message)的分类。 Partition: Topic物理上的分组,一
- Linux环境下安装JDK
roadrunners
jdklinux
1、准备工作
创建JDK的安装目录:
mkdir -p /usr/java/
下载JDK,找到适合自己系统的JDK版本进行下载:
http://www.oracle.com/technetwork/java/javase/downloads/index.html
把JDK安装包下载到/usr/java/目录,然后进行解压:
tar -zxvf jre-7
- Linux忘记root密码的解决思路
tomcat_oracle
linux
1:使用同版本的linux启动系统,chroot到忘记密码的根分区passwd改密码 2:grub启动菜单中加入init=/bin/bash进入系统,不过这时挂载的是只读分区。根据系统的分区情况进一步判断. 3: grub启动菜单中加入 single以单用户进入系统. 4:用以上方法mount到根分区把/etc/passwd中的root密码去除 例如: ro
- 跨浏览器 HTML5 postMessage 方法以及 message 事件模拟实现
xueyou
jsonpjquery框架UIhtml5
postMessage 是 HTML5 新方法,它可以实现跨域窗口之间通讯。到目前为止,只有 IE8+, Firefox 3, Opera 9, Chrome 3和 Safari 4 支持,而本篇文章主要讲述 postMessage 方法与 message 事件跨浏览器实现。postMessage 方法 JSONP 技术不一样,前者是前端擅长跨域文档数据即时通讯,后者擅长针对跨域服务端数据通讯,p