绕过chrome的弹窗拦截机制
2017-05-04 18:16
176 查看
在chrome的安全机制里面,非用户触发的window.open方法,是会被拦截的。举个例子:
上面的代码中,window.open是用户触发的时候,是不会被拦截的,可以正常打开新窗口。再看下面这个:
上面的代码中,用户没有直接出发window.open,而是发出一个ajax请求,window.open方法被放在了ajax的回调函数里,这样的情况是会被拦截的。
那么,当用户点击按钮,发出ajax请求,如何在ajax请求完成后再打开新窗口,又不被拦截呢? 接着往下看:
上面的代码中,用户安点击按钮的时候,先打开一个空白页,再发ajax请求,在ajax回调里面修改新窗口的.location.href,这样就不会被拦截
var btn = $('#btn'); btn.click(function () { //不会被拦截 window.open('http://cssha.com') });
上面的代码中,window.open是用户触发的时候,是不会被拦截的,可以正常打开新窗口。再看下面这个:
var btn = $('#btn'); btn.click(function () { $.ajax({ url: 'ooxx', success: function (url) { //会被拦截 window.open(url); } }) });
上面的代码中,用户没有直接出发window.open,而是发出一个ajax请求,window.open方法被放在了ajax的回调函数里,这样的情况是会被拦截的。
那么,当用户点击按钮,发出ajax请求,如何在ajax请求完成后再打开新窗口,又不被拦截呢? 接着往下看:
var btn = $('#btn'); btn.click(function () { //打开一个不被拦截的新窗口 var newWindow = window.open(); $.ajax({ url: 'ooxx', success: function (url) { //修改新窗口的url newWindow.location.href = url; } }) });
上面的代码中,用户安点击按钮的时候,先打开一个空白页,再发ajax请求,在ajax回调里面修改新窗口的.location.href,这样就不会被拦截
相关文章推荐
- 如何绕过chrome的弹窗拦截机制
- 如何绕过chrome的弹窗拦截机制
- 如何绕过chrome的弹窗拦截机制
- 如何绕过chrome的弹窗拦截机制
- 如何绕过chrome的弹窗拦截机制
- 如何绕过浏览器的弹窗拦截机制
- Chrome将封杀弹窗广告:未弹出已拦截
- chrome拦截window.open弹窗问题的两种解决方式
- 事件拦截机制分析(Android群英传)
- Android短信拦截机制适配的坑(下)--4.4以上系统,主要是6.0
- 使用ICMP协议绕过防火墙拦截
- Android事件拦截/分发/响应 机制
- 快速理解android事件传递拦截机制概念
- 通过虚函数指针绕过虚函数的保护机制
- Android图解浅析事件拦截机制
- Android 事件拦截机制
- js 弹窗被浏览器拦截问题
- dispatch、onIntercept、onTouch三者对MotionEvent的分发、拦截机制分析
- 苹果终端wifi图标点亮慢和portal弹窗机制分析以及处理办法和建议经验案例
- 利用Spring AOP机制拦截方法一例