日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

微信公众号手机无法直接下载APK文件是怎么回事

發(fā)布時(shí)間:2025/3/21 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 微信公众号手机无法直接下载APK文件是怎么回事 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

需求:在微信h5頁(yè)面中下載第三方app —— 安卓, 直接下載apk文件包;iphone,跳轉(zhuǎn)AppStore

分析:微信不支持,在微信中屏蔽了apk文件的下載以及AppStore的跳轉(zhuǎn)(且除非和TX有合作的應(yīng)用,否則也不支持通過(guò)scheme跳轉(zhuǎn)第三方app)

變通方法::


一、借助TX的應(yīng)用市場(chǎng) --‘應(yīng)用寶’:將app上架應(yīng)用寶,在微信中點(diǎn)擊下載按鈕(app的應(yīng)用寶微下載地址),安卓則可跳轉(zhuǎn)應(yīng)用直接進(jìn)行下載,iphone則會(huì)自動(dòng)跳轉(zhuǎn)Appstore(需在TX開(kāi)發(fā)平臺(tái)進(jìn)行配置)


總結(jié):雖然這種方法可以直接跳出微信并進(jìn)行下載,但是需要用戶(hù)在應(yīng)用寶中下載


二、在微信中生成遮罩層,然后指引用戶(hù)點(diǎn)擊微信中右上角的更多按鈕,選擇【在瀏覽器打開(kāi)】(iphone為【在safari中打開(kāi)】,下同)


主要代碼如下(H5頁(yè)面由vue構(gòu)建):


1、識(shí)別手機(jī)類(lèi)型


/* 判斷用戶(hù)手機(jī)為安卓還是iphone */


checkPhone () {


let self = this


let agent = (navigator.userAgent || navigator.vendor || window.opera)


? ? if (agent != null) {


let agentName = agent.toLowerCase()


? ? ? ? if (/android/i.test(agentName)) {


? ? ? ? ? self.isAndroid = true


? ? ? ? } else if (/iphone/i.test(agentName)) {


? ? ? ? ? self.isIOS = true


? ? ? ? }


? }


}


2、識(shí)別微信環(huán)境


/* 判斷是否為微信環(huán)境 */


this.isWeiXin = navigator.userAgent.toLowerCase().indexOf('micromessenger') > -1 ? true : false


3、點(diǎn)擊下載按鈕,顯示遮罩層,并為本H5頁(yè)面url地址上增加hash值‘download’(改變hash值并不會(huì)刷新頁(yè)面,但可讓瀏覽器識(shí)別),并指引用戶(hù)瀏覽器打開(kāi)


/* 點(diǎn)擊下載按鈕 */


downloadApp () {


? ? ? // 微信環(huán)境


? ? ? let self = this


? ? ? self.checkPhone()


? ? ? let agent = (navigator.userAgent || navigator.vendor || window.opera)


? ? ? if (agent != null) {


? ? ? ? let agentName = agent.toLowerCase()


? ? ? ? // this.$alert({text: [agentName]})


? ? ? ? if (self.isAndroid) {


? ? ? ? ? // 微信環(huán)境


? ? ? ? ? if (self.isWeiXin) {


? ? ? ? ? ? self.downloadInWeixin = true


? ? ? ? ? ? window.location.hash = 'download'? // 改變hash,便于瀏覽器打開(kāi)時(shí)直接下載安卓包


? ? ? ? ? ? return


? ? ? ? ? }


? ? ? ? ? // 安卓包下載地址


? ? ? ? ? window.location.href = config.androidDownloadUrl


? ? ? ? } else if (self.isIOS) {


? ? ? ? ? // 微信環(huán)境


? ? ? ? ? if (self.isWeiXin) {


? ? ? ? ? ? self.downloadInWeixin = true


? ? ? ? ? ? window.location.hash = 'download'? ? // 改變hash,便于瀏覽器打開(kāi)時(shí)直接跳轉(zhuǎn)AppStore


? ? ? ? ? ? return


? ? ? ? ? }


? ? ? ? ? // 蘋(píng)果商店鏈接地址


? ? ? ? ? window.location.href = config.iosAppstoreUrl


? ? ? ? } else {


? ? ? ? ? this.$alert({text: ['暫不支持,敬請(qǐng)期待~']})


? ? ? ? }


? ? ? }


? ? }


4、瀏覽器中打開(kāi)加了hash的url地址,識(shí)別hash值,安卓直接彈出apk下載框,iphone則直接跳轉(zhuǎn)AppStore


重中之重:原來(lái)的H5頁(yè)面的url地址后面必須跟上‘#/’, 不然瀏覽器不會(huì)識(shí)別hash值,切記、切記、切記


identityHash () {


if (window.location.hash.includes('download')) {


? ? ? window.location.hash = ''? //? 還原h(huán)ash為空


? ? ? self.checkPhone()


? ? ? if (self.isAndroid) {


? ? ? ? // 安卓,彈出包下載頁(yè)面


? ? ? ? window.location.href = config.androidDownloadUrl


? ? ? } else if (self.isIOS) {


? ? ? ? // ios,直接跳轉(zhuǎn)Appstore


? ? ? ? window.location.href = config.linkToAppstore


? ? ? } else {


? ? ? ? this.$alert({text: ['暫不支持,敬請(qǐng)期待~']})


? ? ? }


? ? }


}



轉(zhuǎn)載于:https://blog.51cto.com/14321053/2390838

總結(jié)

以上是生活随笔為你收集整理的微信公众号手机无法直接下载APK文件是怎么回事的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。