幾乎每一個開發用于微信公眾號頁面的工程師都遇到過微信jssdk報的各種錯誤,通常是permission denied,類似這樣:

通常他們會建議你把debug選項開開,比如這樣:
wechat.config({ debug: true, appId: appId, timestamp: timestamp, nonceStr: nonceStr, signature: signature, jsApiList: ['scanQRCode'], });結果你又遇到了invalid signature。類似這樣:

簽名不對,這是什么意思?可是這簽名是后端給過來的,我怎么知道它為什么不對?后端用的是標準算法,不可能不對啊。
查網上各種教程,或者微信官網,他們總是不厭其煩地告訴你,讓你去檢查簽名算法,然而根本沒有用!
90%的這種情況下,其實只是一個原因:你用于計算簽名的URL地址不對,跟算法沒有任何關系,完全不必浪費時間去看什么簽名算法。
微信要求:如果我們需要在頁面中調用微信的某個方法,則必須用這個頁面的URL地址獲取簽名。聽上去似乎很好理解,但是實際上URL地址包含的部分很多,有問號,有#號,你所要做的是取出#前面的部分。比如說你的URL地址是這樣:https://www.abc.com/abc.html?abc=def#xyz,那么你用于計算簽名的URL地址不可以是https://www.abc.com/abc.html,也不能是https://www.abc.com/abc.html?abc=def#xyz,而必須只能是https://www.abc.com/abc.html?abc=def。
如何獲取當前頁面的URL地址呢?這個很簡單:
let wechaturl = window.location.href.split('#')[0];然而你以為事情就這樣結束了?太天真。你的頁面還是無法正常使用微信函數的。
因為:微信內嵌瀏覽器在iOS和安卓下的表現不一樣。
在安卓下,你確實用上面的方法是可以調用了。但是在iOS下,簽名依然失敗!因為在iOS下,微信需要你傳遞的是入口URL,而不是當前頁面的URL!
比如說,你在微信公眾號的某個菜單鏈接進入了A頁面,然后從A頁面的某個鏈接跳轉到B頁面,然后你在B頁面獲取簽名,如果是在安卓下,你應該用B頁面的URL地址來獲取,但是在iOS下,你還必須用A頁面的URL地址來獲取,否則就還是簽名失敗!
知道了原因,就有很多種解決辦法。
新聞熱點
疑難解答