溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SDK注入權(quán)限驗(yàn)證安卓正常而IOS出現(xiàn)config fail怎么辦

發(fā)布時(shí)間:2021-07-19 14:45:02 來(lái)源:億速云 閱讀:270 作者:小新 欄目:移動(dòng)開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)SDK注入權(quán)限驗(yàn)證安卓正常而IOS出現(xiàn)config fail怎么辦,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

實(shí)測(cè)有效 解決微信游覽器和企業(yè)微信游覽器JSSDK注入權(quán)限驗(yàn)證 安卓正常,IOS出現(xiàn)config fail

一開始我們想到的是可能微信這邊的Bug,但細(xì)想一下應(yīng)該不是。因?yàn)榭赡苌婕暗搅薎OS的底層原理的問題,可能是不受微信所控。(有問題歡迎拍磚)

出現(xiàn)問題得解決問題啊,不能把問題晾在那邊不管,這是程序員的尊嚴(yán)!

我這個(gè)是SPA應(yīng)用,所以拿其中一個(gè)vue項(xiàng)目來(lái)做探討,其他SPA應(yīng)用同理

首先我們想到在安卓中生效,在IOS中不生效是什么原因?

我們把所有設(shè)置都檢查了一遍,最終發(fā)現(xiàn)是當(dāng)前路由location.href不一致的問題

我們可以去嘗試一下去到具體某個(gè)頁(yè)面:

在Android下微信復(fù)制當(dāng)前鏈接然后粘貼到輸入框里,會(huì)發(fā)現(xiàn)路由是具體到某個(gè)路由。例如:www.xxxx.com/news/xxxx

在IOS下微信復(fù)制當(dāng)前鏈接然后粘貼到輸入框里,會(huì)發(fā)現(xiàn)路由是首頁(yè)。例如:wwwx.xxxx.com/index

所以問題就定位在了url上,這次我只拿調(diào)取掃一掃功能,其余功能自行加上。

那我們只需要判斷訪問設(shè)備是安卓還是IOS即可

首先在index.html頁(yè)面中引入JSSDK文件

然后在App.vue文件中

if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) {
 const url = location.href
 const res = await getSignature(url) //獲取設(shè)置config的參數(shù)
 let { timestamp, noncestr, signature, appId } = res.data
 wx.config({
  beta: true,
  debug: false,
  appId: appId,
  timestamp: timestamp,
  nonceStr: noncestr,
  signature: signature,
  jsApiList: ['scanQRCode']
 });
 wx.ready(function () {
  console.log('設(shè)備已經(jīng)可以使用')
 })
}

具體到某個(gè)頁(yè)面的時(shí)候 例如:news下

if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) {
 const url = location.href
 const res = await getSignature(url) //獲取設(shè)置config的參數(shù)
 let { timestamp, noncestr, signature, appId } = res.data
 wx.config({
  beta: true,
  debug: false,
  appId: appId,
  timestamp: timestamp,
  nonceStr: noncestr,
  signature: signature,
  jsApiList: ['scanQRCode']
 });
 wx.ready(function () {
  console.log('設(shè)備已經(jīng)可以使用')
 })
}

僅限于在微信自帶的游覽器上。企業(yè)微信自帶的游覽器這方法是不行的。

通過微信企業(yè)瀏覽器掃碼獲取到的微信瀏覽器信息如下:(圖片摘取于CSDN)

SDK注入權(quán)限驗(yàn)證安卓正常而IOS出現(xiàn)config fail怎么辦

微信客戶端掃碼獲取到的信息如下:

SDK注入權(quán)限驗(yàn)證安卓正常而IOS出現(xiàn)config fail怎么辦

對(duì)比企業(yè)微信游覽其和微信游覽器的信息,多出了wxwork。那么我們只需要添加多一個(gè)判斷條件就好了

在App.vue文件中

if (/(wxwork)/i.test(navigator.userAgent)) {
 return
}
if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) {
 const url = location.href
 const res = await getSignature(url) //獲取設(shè)置config的參數(shù)
 let { timestamp, noncestr, signature, appId } = res.data
 wx.config({
  beta: true,
  debug: false,
  appId: appId,
  timestamp: timestamp,
  nonceStr: noncestr,
  signature: signature,
  jsApiList: ['scanQRCode']
 });
 wx.ready(function () {
  console.log('設(shè)備已經(jīng)可以使用')
 })
}

在news文件中

if (/(wxwork)/i.test(navigator.userAgent)) {
 return
}
if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) {
 const url = location.href
 const res = await getSignature(url) //獲取設(shè)置config的參數(shù)
 let { timestamp, noncestr, signature, appId } = res.data
 wx.config({
  beta: true,
  debug: false,
  appId: appId,
  timestamp: timestamp,
  nonceStr: noncestr,
  signature: signature,
  jsApiList: ['scanQRCode']
 });
 wx.ready(function () {
  console.log('設(shè)備已經(jīng)可以使用')
 })
}

關(guān)于“SDK注入權(quán)限驗(yàn)證安卓正常而IOS出現(xiàn)config fail怎么辦”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI