ios 使用window.location.href 不能跳轉微信短鏈處理過程以及解決方法

需求背景:

? ? ? ? 由h5提供頁面,通過后臺請求微信api生成對應的schemal短鏈,該h5頁面嵌入到原生的ios以及安卓app上,當用戶點擊后通過短連接跳轉到其他小程序中

以下為生成微信scheme代碼示例,生成后短鏈為:weixin://dl/business/?t=l77aMn7aZF 這種

 /***  生成短連接* @param data* @return*/public static String getUrlScheme(JSONObject data) {try {log.info("==>獲取小程序跳轉地址,mchnt:{}", data);String appId = data.getString("appId");String secret = data.getString("secret");String accessToken = getAccessToken(appId, secret);return generateWechatScheme(accessToken, data);} catch (Exception e) {log.error("==>獲取小程序跳轉地址失敗", e);throw new FuiouException("5022","獲取小程序跳轉地址失敗");}}/*** 向微信服務端請求生成小程序 scheme*/public static String generateWechatScheme(String accessToken, JSONObject data) {CloseableHttpClient client = HttpClientUtil.createClient();String url = "https://api.weixin.qq.com/wxa/generatescheme?access_token=" + accessToken;HttpPost request = new HttpPost(url);request.setHeader("Content-Type", "application/json; charset=utf-8");String path = data.get("path").toString();String queryStr = data.get("queryStr").toString();String env_version = data.get("env_version").toString();// 構建請求體 JSONString requestBody = "{\"jump_wxa\":{\"path\":\"" + path + "\",\"query\":\"" + queryStr+ "\",\"env_version\":\"" + env_version+ "\"},\"is_expire\":false,\"expire_type\":1,\"expire_interval\":" + 1 + "}";request.setEntity(new StringEntity(requestBody, StandardCharsets.UTF_8));log.info("==>調用微信generatescheme接口,request body:" + requestBody);String response = HttpClientUtil.executeAndClose(client, request);log.info("==>調用微信generatescheme接口,response:" + response);JSONObject jsResp = JSONObject.parseObject(response);String openlink = jsResp.getString("openlink");log.info("==>獲取到的微信小程序scheme:" + openlink);return openlink;}/*** 獲取 access_token*/private static String getAccessToken(String appId, String secret) {String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appId + "&secret=" + secret;CloseableHttpClient client = HttpClientUtil.createClient();HttpGet request = new HttpGet(url);String response = HttpClientUtil.executeAndClose(client, request);log.info("==>獲取微信accessToken,response:" + response);JSONObject jsResp = JSONObject.parseObject(response);String accessToken = jsResp.getString("access_token");return accessToken;}

所遇到問題:

? ? ? ? 短鏈如:weixin://dl/business/?t=l77aMn7aZF

? ? ? ? 通過短鏈在前端利用js? window.location.href =?weixin://dl/business/?t=l77aMn7aZF 進行跳轉,在安卓上面能正常跳轉,但是ios無法跳轉,且沒有反應

解決問題思路

? ? ? ? 1、檢查schema 是否正確,在ios真機測試也是可以跳;排除

? ? ? ? 2、將window.location.href 替換為?window.location? 以及換為 windos.open(xx) 等多種方式均不可行;

? ? ? ?3、懷疑是h5頁面的meta 寫的有問題,隨即替換為meta 信息,進行測試,還是不行;

? ? ? ?4、本來都準備放棄,讓ios提供一個原生方法,自己這邊判斷如果是ios就調用原生方法進行跳轉,附一段js ios 判斷代碼

function isIos(){var u = window.navigator.userAgent;var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);return     isiOS;
}

? ? ? ?5、這時候經同事提醒,將鏈接放到其他頁面,看是否可跳轉,然后將鏈接放到首頁測試是否可以跳轉,這時候神奇的事情發生了,竟然ios 能正常跳了,同樣是 window.location.href?

? ? ?6、拿到h5頁面開始分析首頁和2級頁面的區別,發現首頁沒有無層級關系,而二級目錄有一個ifream頁面,以下為二級頁面

? ??

最終結局方案

? ? ? ? 經過以上分析后得知,window.location.href 不能跳出父框架,因為需要喚起小程序,所以需要跳出ifream ,但是安卓沒問題,可能是語法的限制,最終知道解決方案

window.top.location.href = xx 微信的短鏈     及可正常跳轉

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/711004.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/711004.shtml
英文地址,請注明出處:http://en.pswp.cn/news/711004.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

linux常見signal信號總結

文章目錄 SIGSEGVSIGALRMSIGINTSIGCHLD SIGSEGV 在POSIX兼容的平臺上,SIGSEGV是當一個進程執行了一個無效的內存引用,或發生段錯誤時發送給它的信號 SIGALRM 已到通過調用alarm函數注冊的時間 SIGINT 輸入cltrlc SIGCHLD 子進程終止

【分享】在 Python 編程中提高效率的技巧

在 Python 編程中,有許多技巧可以幫助提高效率,從代碼優化到工作流程改進。 以下是一些可以分享的技巧: 1、使用列表推導式和生成器表達式:列表推導式和生成器表達式是 Python 中的一種簡潔而高效的方法,用于快速創建…

Azure[Sky] Dynamic Skybox

Azure[Sky] Dynamic Skybox是一個完整而穩健的天空系統,它可將你的項目提升大到其他層次。 Azure[Sky] 不僅適合使用現實圖片的項目,事實上,該系統用在風格化圖片的項目也很不粗,甚至效果更好。使用 Azure,每種風格都能實現最佳效果。 性能: 在開發此資源的過程中,性能是…

【Android】屬性動畫

在屬性動畫出現之前,Android 系統提供的動畫只有幀動畫和 View 動畫。View 動畫我們都了解,它提供了 AlphaAnimation、RotateAnimation、TranslateAnimation、ScaleAnimation 這4種動畫方式,并提供了 AnimationSet 動畫集合來混合使用多種動畫…

35. 【Linux教程】Linux 修改用戶組

前面小節介紹了如何添加用戶組,本小節介紹如何給已經添加的新用戶組修改信息,從 /etc/group 文件信息可以看到,用戶組的信息比用戶信息項少,和 usermod 命令類似,用戶組的信息可以使用 groupmod 命令修改。 1. groupmo…

為了董宇輝,老婆跟我打起來了!寫下一份深刻檢討

兩個月前,因為討論董宇輝小作文事件,跟老婆吵起來了。起因就為了兩句話,寫了這份檢討!給大家分享一下。 老婆在網上刷了兩晚關于董宇輝小作文的視頻,一直為董宇輝喊冤、打抱不平。起初,我跟老婆的想法&…

類型字段定義影響WebApi傳值及SqlSugar調用Select創建新對象

ASP.NET Core編寫的WebApi,由于輸入參數較多,專門定義了輸入參數類并設置[FromBody]方式傳值,但測試時始終無法通過postman將輸入參數值傳遞給WebApi,condition對象的所有屬性值一直都為空。同時在WebApi內部調用SqlSugar查詢數據…

怎樣消除視頻上的字幕和文字?3個方法值得推薦

怎樣消除視頻上的字幕和文字?消除視頻上的字幕和文字不僅是一個常見的需求,更是一個對視頻內容質量提升的關鍵步驟。特別是在處理從網絡下載的帶有水印或標識的視頻時,這些額外的文字和信息往往會干擾觀眾的觀看體驗,甚至可能影響…

three.js環境及使用教程

開發環境 npm i three0.156.1 npm i types/three0.156.0入門代碼 index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" />…

Pytorch 復習總結 5

Pytorch 復習總結&#xff0c;僅供筆者使用&#xff0c;參考教材&#xff1a; 《動手學深度學習》Stanford University: Practical Machine Learning 本文主要內容為&#xff1a;Pytorch 卷積神經網絡。 本文先介紹了 Pytorch 語法匯總&#xff1a; Pytorch 張量的常見運算、…

【數據結構】順序表和鏈表的對比,在各種情況下如何選擇

順序表詳細內容&#xff1a; 【數據結構】線性表 順序表&#xff08;動態、靜態分配&#xff0c;插入刪除查找基本操作&#xff09;解析完整代碼 單鏈表詳細內容&#xff1a; 【數據結構】單鏈表解析完整代碼&#xff08;插入、刪除、尾插法、頭插法、按值和按位查找、前插和后…

IDEA開發環境的安裝與編寫第一個程序

1.下載 IDEA&#xff08;全稱IntelliJ IDEA&#xff09;是用于Java程序開發的集成環境&#xff08;也可用于其他語言&#xff09;&#xff0c;它在業界被公認是最好的Java開發工具之一&#xff0c;尤其在智能代碼助手、代碼自動提示、重構、J2EE支持、Ant、JUnit、CVS整合、代…

【Java萬花筒】醫學圖像處理的“探索”:探索更多可能性和應用場景

使用 Java 庫打造醫學圖像處理的“神器” 前言 隨著醫學圖像在醫療保健領域中的不斷發展&#xff0c;醫學圖像處理也成為了一項非常重要的研究領域。在此背景下&#xff0c;本文將介紹三個常用的 Java 醫學圖像處理庫&#xff1a;ImageJ、MIPAV 和 ITK。這些庫提供了豐富的圖…

代碼隨想錄算法訓練營day46| 139. 單詞拆分、背包問題總結

139、單詞拆分&#xff1a; class Solution(object):def wordBreak(self, s, wordDict):""":type s: str:type wordDict: List[str]:rtype: bool"""n len(s)dp [False] * (n 1)dp[0] Truemap_word set(wordDict)for j in range(1, n 1):f…

3月1日.開始記錄

今天事項安排 打算今天開始&#xff0c;每天工作日記錄&#x1f4dd;一下當天大致的事項。 有說法是每天開始工作前記錄下自己的清單&#xff0c;可以讓當天做事太過發散。這對于我這種喜歡發散的人是個有用的技巧&#xff08;笑 上午 把昨天的日報交了 30 min 把今天的工作放…

算法日記——前綴和、差分

文章目錄 洛谷 B3612 求區間和洛谷 P1387 最大正方形洛谷 P3397 地毯 洛谷 B3612 求區間和 題目鏈接&#xff1a;洛谷 B3612 求區間和 思路&#xff1a; 一維前綴和的模板題。所謂前綴和&#xff0c;就是對原數組前i個元素求和&#xff0c;這個值作為新元素放在下標i的位置。 …

C++智能指針_C++回顧

發展歷史 C98中產生了第一個智能指針auto_ptr&#xff1b; Cboost給出了更實用的scoped_ptr和shared_ptr和weak_ptr&#xff1b; CTR1&#xff0c;引入了shared_ptr等&#xff0c;不過TR1并不是標準版&#xff1b; C11引入了unique_ptr和shared_ptr和weak_ptr。需要注意的是…

Mamba與MoE架構強強聯合,Mamba-MoE高效提升LLM計算效率和可擴展性

論文題目&#xff1a; MoE-Mamba: Efficient Selective State Space Models with Mixture of Experts 論文鏈接&#xff1a; https://arxiv.org/abs/2401.04081 代碼倉庫&#xff1a; GitHub - llm-random/llm-random 作為大型語言模型&#xff08;LLM&#xff09;基礎架構的后…

新一代科學計算與系統建模仿真平臺MWORKS 2024a震撼發布:產品強勢進化,更新亮點速覽!

2月25日&#xff0c;同元軟控成功舉辦MWORKS 2024產品發布會&#xff0c;會上公布了新版MWORKS的設計理念、關鍵技術、版本亮點、產品特性以及重大改進。當前&#xff0c;科學計算與系統建模仿真平臺MWORKS 2024a已正式上線&#xff0c;開放下載。 MWORKS已成為全球第4個完整的…

全量知識系統問題及SmartChat給出的答復 之6 三套工具之1

Q15. 提出想法和問題 前面說過&#xff0c;DDD在我要設計的全量知識系統中位于中間層&#xff0c;是專門用來解決“知識湯”問題的。 解決的思路就是以將為在特定領域中的公司經營提供一個責任-權限平面為目的&#xff0c;幫助他們調整商業模式以及組建恰當的組織&#xff0c…