1. 程式人生 > 程式設計 >微信分享invalid signature簽名錯誤踩過的坑

微信分享invalid signature簽名錯誤踩過的坑

前一段時間做了一個微信分享的東西,而且前端框架用的是VUE,被這個東西快折磨瘋了,一個列表頁,一個詳情頁,分享詳情頁的時候,會報錯invalid signature簽名錯誤。

當時就不淡定了,然後開始了排坑之路,根據官網的各種校驗錯誤問題,沒有發現有什麼區別

建議按如下順序檢查:

1.確認簽名演算法正確,可用http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign頁面工具進行校驗。

2.確認config中nonceStr(js中駝峰標準大寫S),timestamp與用以簽名中的對應noncestr,timestamp一致。

3.確認url是頁面完整的url(請在當前頁面alert(location.href.split('#')[0])

確認),包括'http(s)://'部分,以及'?'後面的GET引數部分,但不包括'#'hash後面的部分。

4.確認 config 中的 appid 與用來獲取 jsapi_ticket 的 appid 一致。

5.確保一定快取access_token和jsapi_ticket。

6.確保你獲取用來簽名的url是動態獲取的,動態頁面可參見例項程式碼中php的實現方式。如果是html的靜態頁面在前端通過ajax將url傳到後臺簽名,前端需要用js獲取當前頁面除去'#'hash部分的連結(可用location.href.split('#')[0]獲取,而且需要encodeURIComponent),因為頁面一旦分享,微信客戶端會在你的連結末尾加入其它引數,如果不是動態獲取當前連結,將導致分享後的頁面簽名失敗。

究竟什麼導致呢,後來發現是history在微信中的問題,就是當從列表進入詳情頁的時候,往後臺傳入URL,跟你直接從詳情頁進入傳的URL不一致。比如:A=>B,分享B

這時候你需要記錄初始頁的url,解決辦法在你的main.js裡,新增

router.beforeEach((to,from,next) => {
 if (!window.initUrl) {
 window.initUrl = location.href.split('#')[0]
 }
 next()
})

然後在你的詳情頁裡B獲取

url: '....?url=' + encodeURIComponent(that.isIosOrAndroid() === 'android' ? location.href.split('#')[0] : window.initUrl)

在這裡要判斷是android還是ios,因為再android裡顯示是正常的,所以就用

location.href.split('#')[0]

直接獲取當前的url即可。

// 判斷ios還是android
 Vue.prototype.isIosOrAndroid = function () {
 let u = navigator.userAgent;
 let isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1 // android終端
 let isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/) // ios終端
 let isStr = ''
 if (isAndroid) {
 isStr = 'android'
 }
 if (isiOS) {
 isStr = 'ios'
 }
 return isStr
 }

總結

到此這篇關於微信分享invalid signature簽名錯誤踩過的坑的文章就介紹到這了,更多相關微信分享invalid signature簽名錯誤內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!