欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信分享invalid signature簽名錯(cuò)誤踩過的坑

 更新時(shí)間:2020年04月11日 10:25:01   作者:lovlin_l  
這篇文章主要介紹了微信分享invalid signature簽名錯(cuò)誤踩過的坑,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

前一段時(shí)間做了一個(gè)微信分享的東西,而且前端框架用的是VUE,被這個(gè)東西快折磨瘋了,一個(gè)列表頁(yè),一個(gè)詳情頁(yè),分享詳情頁(yè)的時(shí)候,會(huì)報(bào)錯(cuò)invalid signature簽名錯(cuò)誤。

當(dāng)時(shí)就不淡定了,然后開始了排坑之路,根據(jù)官網(wǎng)的各種校驗(yàn)錯(cuò)誤問題,沒有發(fā)現(xiàn)有什么區(qū)別

建議按如下順序檢查:

1.確認(rèn)簽名算法正確,可用http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 頁(yè)面工具進(jìn)行校驗(yàn)。

2.確認(rèn)config中nonceStr(js中駝峰標(biāo)準(zhǔn)大寫S), timestamp與用以簽名中的對(duì)應(yīng)noncestr, timestamp一致。

3.確認(rèn)url是頁(yè)面完整的url(請(qǐng)?jiān)诋?dāng)前頁(yè)面alert(location.href.split('#')[0])確認(rèn)),包括'http(s)://'部分,以及'?'后面的GET參數(shù)部分,但不包括'#'hash后面的部分。

4.確認(rèn) config 中的 appid 與用來獲取 jsapi_ticket 的 appid 一致。

5.確保一定緩存access_token和jsapi_ticket。

6.確保你獲取用來簽名的url是動(dòng)態(tài)獲取的,動(dòng)態(tài)頁(yè)面可參見實(shí)例代碼中php的實(shí)現(xiàn)方式。如果是html的靜態(tài)頁(yè)面在前端通過ajax將url傳到后臺(tái)簽名,前端需要用js獲取當(dāng)前頁(yè)面除去'#'hash部分的鏈接(可用location.href.split('#')[0]獲取,而且需要encodeURIComponent),因?yàn)轫?yè)面一旦分享,微信客戶端會(huì)在你的鏈接末尾加入其它參數(shù),如果不是動(dòng)態(tài)獲取當(dāng)前鏈接,將導(dǎo)致分享后的頁(yè)面簽名失敗。

究竟什么導(dǎo)致呢,后來發(fā)現(xiàn)是history在微信中的問題,就是當(dāng)從列表進(jìn)入詳情頁(yè)的時(shí)候,往后臺(tái)傳入U(xiǎn)RL,跟你直接從詳情頁(yè)進(jìn)入傳的URL不一致。比如:A=>B,分享B

這時(shí)候你需要記錄初始頁(yè)的url,解決辦法在你的main.js里,添加

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

然后在你的詳情頁(yè)里B獲取

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

在這里要判斷是android還是ios,因?yàn)樵賏ndroid里顯示是正常的,所以就用

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

直接獲取當(dāng)前的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
 }

總結(jié)

到此這篇關(guān)于微信分享invalid signature簽名錯(cuò)誤踩過的坑的文章就介紹到這了,更多相關(guān)微信分享invalid signature簽名錯(cuò)誤內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS實(shí)現(xiàn)的base64加密解密操作示例

    JS實(shí)現(xiàn)的base64加密解密操作示例

    這篇文章主要介紹了JS實(shí)現(xiàn)的base64加密解密操作,結(jié)合實(shí)例形式分析了基于javascript的base64加密與解密函數(shù)定義與使用相關(guān)操作技巧,需要的朋友可以參考下
    2018-04-04
  • opencv 識(shí)別微信登錄驗(yàn)證滑動(dòng)塊位置

    opencv 識(shí)別微信登錄驗(yàn)證滑動(dòng)塊位置

    這篇文章主要介紹了opencv 識(shí)別微信登錄驗(yàn)證滑動(dòng)塊位置及各自的優(yōu)缺點(diǎn),需要的朋友可以參考下
    2018-08-08
  • 微信小程序?qū)崿F(xiàn)日歷小功能

    微信小程序?qū)崿F(xiàn)日歷小功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)日歷小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 記一次webapck4 配置文件無效的解決歷程

    記一次webapck4 配置文件無效的解決歷程

    這篇文章主要介紹了記一次webapck4 配置文件無效的解決歷程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解JS 比較兩個(gè)Json對(duì)象的值是否相等的實(shí)例

    詳解JS 比較兩個(gè)Json對(duì)象的值是否相等的實(shí)例

    這篇文章主要介紹了JS 比較兩個(gè)Json對(duì)象的值是否相等的實(shí)例,有需要的朋友可以參考一下
    2013-11-11
  • fastadmin如何讓后臺(tái)的日期顯示成年月日格式(推薦)

    fastadmin如何讓后臺(tái)的日期顯示成年月日格式(推薦)

    FastAdmin是一款基于ThinkPHP5+Bootstrap的極速后臺(tái)開發(fā)框架,本文給大家介紹fastadmin的后臺(tái)時(shí)間戳字段如何顯示成年月日的日期格式,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • H5手機(jī)端多文件上傳預(yù)覽插件

    H5手機(jī)端多文件上傳預(yù)覽插件

    這篇文章主要為大家詳細(xì)介紹了H5圖片上傳插件,基于zepto,支持多文件上傳,進(jìn)度和圖片預(yù)覽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • layui左側(cè)菜單欄鼠標(biāo)懸停顯示菜單文字功能實(shí)現(xiàn)

    layui左側(cè)菜單欄鼠標(biāo)懸停顯示菜單文字功能實(shí)現(xiàn)

    layui封裝的左側(cè)菜單是固定寬度的,且左側(cè)菜單欄在css里改變寬度,效果并不是很好(還設(shè)計(jì)頭部菜單欄),如果寫js來讓菜單欄能夠拉伸,也比較麻煩,那怎么最簡(jiǎn)單的,讓用戶看到菜單的文字呢,下面給大家分享layui左側(cè)菜單欄鼠標(biāo)懸停顯示菜單文字功能實(shí)現(xiàn),感興趣的朋友一起看看吧
    2024-06-06
  • 最新評(píng)論