兩種Ajax開啟新視窗被瀏覽器攔截解決方法

小云云
發布: 2023-03-19 11:48:02
原創
1547 人瀏覽過

本文主要和大家分享,最近在做支付時發現打開支付窗口時被瀏覽器攔截了,百度了一下才發現是因為打開窗口前用ajax驗證是否能支付,所以不是用戶主動觸發的打開ixin窗口,瀏覽器認為這樣不安全,所以給攔截了。

解決辦法一

先開始打開一個空的新窗口,然後改變新窗口的url,具體代碼為

var wd = window.open();
$.ajax({
  type: "POST",
  dataType: "json",
  url: URL,
  data: {orderNo:orderNo},
  success: function(data) {
    if(data.status=='success'){
      wd.location.href = 'http://www.baidu.com';
    }else{ 
      alert('订单不能支付!'); 
    }
  },error: function(data) {
    alert("正在加载请稍后!");
  }
});
登入後複製

這種實現方式有個弊端,就是不管ajax有沒有成功,都會執行var wd = window.open();這行程式碼,所以成功和失敗都會打開一個新窗口,除非在失敗後進行關閉,但這樣用戶體驗會非常不好,所以我用的第二種方式去實現的。

解決方案二

因為ajax是預設是異步的,這樣效能高,使用者體驗好,但這也導致了安全性問題,要讓瀏覽器認為彈出新視窗是安全的,必須讓彈新視窗之前所有的ajax是同步的,具體程式碼為

$.ajax({
  type: "POST",
  dataType: "json",
  url: URL,
  async: false,//同步请求
  data: {orderNo:orderNo},
  success: function(data) {
     if(data.status=='success'){
       window.open("www.baidu.com");
     }else{
       alert('订单不能支付!');
     }
  },
  error: function(data) {
    alert("正在加载请稍后!");
  }
});
登入後複製

相關推薦:

ajax回呼開啟新視窗防止瀏覽器攔截有效方法

iframe 跨站被瀏覽器攔截

#JS判斷網頁廣告是否被瀏覽器攔截過濾的程式碼_javascript技巧

以上是兩種Ajax開啟新視窗被瀏覽器攔截解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!