Swift H5喚起支付寶支付和微信支付

讓你不再迷茫

image

網(wǎng)上有很多講H5喚起支付寶和微信支付的文章,但是大部分都是粘貼代碼(并且代碼不完全),沒有講為什么,導(dǎo)致做這個(gè)功能的時(shí)候不好下手,下面我詳細(xì)講解一下應(yīng)該怎么做,為什么要這么做,本文是Swift版本,OC可自行翻譯.

首先,原理是當(dāng)用戶在H5想要喚起支付寶或者微信的時(shí)候,會出現(xiàn)彈框,請求前往,我們的核心就是攔截這條URL,然后轉(zhuǎn)換成我們自己想要的URL,于是我們的一切操作都是在WKWebView的代理方面里面攔截

func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
}
  • 支付寶支付
 func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
        let urlString = navigationAction.request.url?.absoluteString
        // 阿里支付 ---> 發(fā)現(xiàn)帶有alipays或alipay的鏈接就攔截下來,并重置URL,喚起APP
        if let urlString = urlString, urlString.hasPrefix("alipays://") || urlString.hasPrefix("alipay://") {
            decisionHandler(.cancel)
            guard let newURLS = URL(string: YTPayUtil.changeAliPayScheme(aliPayUrl: urlString)) else {
                return
            }
            toOpenUrl(url: newURLS)
            self.isload = true
            return
        }
        self.isload = false
        decisionHandler(.allow)
        return
    }
  • 微信支付
    和支付寶的原理類似,但是復(fù)雜在第一次攔截以后需要在webview上重新加載,導(dǎo)致的后果就是要攔截第二次,攔截成功后就喚起APP
    func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
        let urlString = navigationAction.request.url?.absoluteString
        //1.攔截第一次,并在webview重新加載,攔截的目的是為了換我們自己的redirect_url
        if urlString?.range(of: "https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb") != nil && !self.isload{
            if var mUrlStr = urlString {
                decisionHandler(.cancel)
                // 替換掉redirect_url
                mUrlStr = mUrlStr.replacingOccurrences(of: "redirect_url=", with: "redirect_url_app=")
                guard let newURLS = URL(string: mUrlStr) else {
                    return
                }
                var mRequest = URLRequest.init(url: newURLS, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 60)
                mRequest.setValue("\(kWechatScheme)://", forHTTPHeaderField: "Referer")
                webView.load(mRequest)
                self.isload = true
                return
            }
        }
        2.發(fā)現(xiàn)weixin://wap/pay開發(fā)的鏈接,說明是微信支付的鏈接,攔截下來并喚起APP
        if urlString?.range(of: "weixin://wap/pay?") != nil {
            self.isload = false
            decisionHandler(.cancel)
            if let mUrlStr = urlString, let openWX = URL(string: mUrlStr) {
                toOpenUrl(url: openWX)
            }
            return
        }
        
        self.isload = false
        decisionHandler(.allow)
        return
    }
  • 公用方法
func toOpenUrl(url: URL) {
        if (UIApplication.shared.canOpenURL(url)) {
            UIApplication.shared.openURL(url)
        }
        // 回到上一級頁面
        // 1.防止因?yàn)閘oad上面的微信支付url而出現(xiàn)的白屏
        // 2.防止停留在支付寶支付確認(rèn)頁面
        DispatchQueue.main.asyncAfter(deadline: .now() + 0.5) {
            if self.wkWebView?.canGoBack ?? false {
                self.wkWebView?.goBack()
            }
        }
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子停士,更是在濱河造成了極大的恐慌,老刑警劉巖唯鸭,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡娇哆,警方通過查閱死者的電腦和手機(jī)末荐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門侧纯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人甲脏,你說我怎么就攤上這事眶熬。” “怎么了块请?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵娜氏,是天一觀的道長。 經(jīng)常有香客問我墩新,道長贸弥,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任海渊,我火速辦了婚禮绵疲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘臣疑。我一直安慰自己盔憨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布朝捆。 她就那樣靜靜地躺著般渡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪芙盘。 梳的紋絲不亂的頭發(fā)上驯用,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天,我揣著相機(jī)與錄音儒老,去河邊找鬼蝴乔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛驮樊,可吹牛的內(nèi)容都是我干的薇正。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼囚衔,長吁一口氣:“原來是場噩夢啊……” “哼挖腰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起练湿,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤猴仑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后肥哎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體辽俗,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疾渣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了崖飘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片榴捡。...
    茶點(diǎn)故事閱讀 38,018評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖朱浴,靈堂內(nèi)的尸體忽然破棺而出吊圾,到底是詐尸還是另有隱情,我是刑警寧澤赊琳,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布街夭,位于F島的核電站,受9級特大地震影響躏筏,放射性物質(zhì)發(fā)生泄漏板丽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一趁尼、第九天 我趴在偏房一處隱蔽的房頂上張望埃碱。 院中可真熱鬧,春花似錦酥泞、人聲如沸砚殿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽似炎。三九已至,卻和暖如春悯姊,著一層夾襖步出監(jiān)牢的瞬間羡藐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工悯许, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留仆嗦,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓先壕,卻偏偏與公主長得像瘩扼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子垃僚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容