vue 微信分享回調(diào)iOS和安卓回調(diào)出現(xiàn)錯誤的解決
產(chǎn)品需求:在微信內(nèi)分享需要手動配置的分享地址、分享圖片與內(nèi)容描述,引導(dǎo)用戶分享,并在微信分享成功回調(diào)內(nèi)進行相應(yīng)的操作。
首先需要在項目中引入微信jsSDk包,然后通過接口獲取后臺簽名。
封裝函數(shù)獲取微信分享必填參數(shù)
其中的jsApiList中填的是需要使用的微信分享js接口的列表,參數(shù)URL默認是location.href,即分享當(dāng)前頁面的URL。
在需要分享的頁面引入封裝的函數(shù)
然后通過wxShare方法將URL和配置的參數(shù)傳入,link參數(shù)是分享出去的鏈接,必須與當(dāng)前頁面的對應(yīng)js安全域名一致;
...shareData就是在函數(shù)內(nèi)傳對象,進行解構(gòu)賦值es6寫法
但是在測試過程中發(fā)現(xiàn):
1.同一套程序,andriod分享正常,ios分享報簽名不正確,主要原因是微信的ios和安卓處理方式不一樣,ios不會刷新當(dāng)前的頁面地址,使用的是history的記錄地址,所以每次分享出來的鏈接,都是第一個進入系統(tǒng)頁面的鏈接,當(dāng)跳轉(zhuǎn)到子頁面的時候,系統(tǒng)就會識別打開的url和簽名的url不一致導(dǎo)致簽名不正確
2.由于單頁面的hash模式會自帶#號,但是分享的時候會將#號后面的參數(shù)變成無效,導(dǎo)致想傳參數(shù)都傳不過去,可以做一個頁面沒有#號的,然后統(tǒng)一帶參數(shù)分享到這個頁面然后再重定向到指定的vue頁面
解決方法:在向后臺發(fā)送請求獲取微信簽名的時候?qū)鹘o后臺的URL的#后面的參數(shù)截去,后臺根據(jù)截取完的URL生成簽名就能實現(xiàn)安卓和iOS分享回調(diào)成功的問題。
補充知識:使用Vue全家桶進行微信分享時出現(xiàn)的錯誤
使用vue.js進行微信H5頁面開發(fā),開發(fā)過程中先進行oAuth身份驗證。后使用JSSDK,進行微信分享。分享時會出現(xiàn)不調(diào)用自定義分享界面的情況,但是在刷新后可以正常顯示,
如下:
正常進入分享:
刷新后分享:
由于Vue和微信調(diào)試環(huán)境的問題,在經(jīng)過幾次痛苦的嘗試后,我們發(fā)現(xiàn)了一個現(xiàn)象,那就是,如果此時點擊使用Safari打開,會出現(xiàn):
這是我們在使用oAuth認證時跳轉(zhuǎn)的中間界面(從oauth回調(diào)的頁面),但是在使用微信調(diào)試工具的時候,顯示的url為正確頁面,既為從回調(diào)頁面跳轉(zhuǎn)的頁面。
我們知道,在使用JSSDK進行微信認證的時候,需要使用當(dāng)前url調(diào)用wxcofig,那會不會有一種可能,當(dāng)vue進行頁面跳轉(zhuǎn)的時候,微信瀏覽器仍然認為當(dāng)前頁面在原頁面,所以導(dǎo)致傳遞的url和微信認為你的url不一致,所以導(dǎo)致認證錯誤。
于是在嘗試給wxconfig傳遞url的時候,使用了跳轉(zhuǎn)前中間結(jié)果的url(既,保持傳遞給認證的url和使用Safari打開的url一致),結(jié)果居然就行了。。。
行吧,算是微信在兼容vue的時候的一個坑,但愿大家以后能盡早跳出來。。。
以上這篇vue 微信分享回調(diào)iOS和安卓回調(diào)出現(xiàn)錯誤的解決就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
VUE +Element 實現(xiàn)多個字段值拼接功能
這篇文章主要介紹了VUE +Element 實現(xiàn)多個字段值拼接,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04vue中render函數(shù)和h函數(shù)以及jsx的使用方式
這篇文章主要介紹了vue中render函數(shù)和h函數(shù)以及jsx的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08不依任何賴第三方,單純用vue實現(xiàn)Tree 樹形控件的案例
這篇文章主要介紹了不依任何賴第三方,單純用vue實現(xiàn)Tree 樹形控件的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09淺談Vue使用Cascader級聯(lián)選擇器數(shù)據(jù)回顯中的坑
這篇文章主要介紹了淺談Vue使用Cascader級聯(lián)選擇器數(shù)據(jù)回顯中的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10Vue3使用路由及配置vite.alias簡化導(dǎo)入寫法的過程詳解
這篇文章主要介紹了Vue3使用路由及配置vite.alias簡化導(dǎo)入寫法,本文通過實例代碼給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-11-11