uni-app開發跨平臺小程式開發的諸多坑【轉載】

来源:https://www.cnblogs.com/gitvimdotcom/archive/2023/03/21/17238598.html
-Advertisement-
Play Games

前言 在initEvents中發現的有意思的東西,就是 Vue 針對 Error 的處理,說實話之前壓根沒在意過 Vue 是如何收集處理 Error 的; errorHandler:https://v2.cn.vuejs.org/v2/api#errorHandler ?> 從 2.2.0 起,這個 ...


uni-app開發跨平臺小程式開發的諸多坑,最近用uni-app開發小程式的時候遇到不少了。本篇收集和記錄自己在開發小程式過中遇到的問題和解決辦法。之前有很多問題解決了,沒記錄在案。往後遇到的問題,我儘量記錄下來。部分小程式平臺不好開發,尤其是需要相容多個平臺,所以如果你和我一樣,想必避免不了遇到 uni-app開發跨平臺小程式開發的諸多坑。

根據平臺的不同,我預期開發的小程式包括微信、QQ、抖音、快手,百度、支付寶、小紅書(pass,不支持個人及個體戶)、京東(pass,不支持個人及個體戶)。

開發跨平臺小程式從登錄開始說起。

登錄邏輯從 uni.checkSession 開始的,支付寶小程式率先登場第一個不支持,所以支付寶小程式接入登錄邏輯相容也暫停。

uni-app 的 uni.login 已經不支持百度小程式了,改成用 swan.getLoginCode 獲取 Authrization Code 來調用 getSessionKey 介面獲取 Session Key 和 open_id。說個題外話,從 github 上開源的百度介面 go 版本SDK 慘淡的7個 star 來看,這個平臺是不是沒接入的必要了?

申請了appid之後,後來上傳發佈小程式時,突然支付寶的appid和app_secret秘鑰找不到了,沒找到藏在哪裡。懵逼了好一陣,為啥小程式相關的設置裡面沒有appid的信息?最後找到賬號中心才看見。

支付寶賬號中心有關秘鑰信息


還發現需要下載支付寶秘鑰生成工具,設置驗簽,應該是所有的小程式平臺中,最複雜的一個了。看上去應該是 Java 開發的,文檔也是完全從 Java 技術人員的角度給出。這一點上,從個人開發接入的體驗上感受,抖音、微信、快手的介面文檔相比於支付寶對開發者要相對友好一些。

支付寶開放平臺秘鑰工具秘鑰設置 支付寶小程式公鑰生成

支付寶小程式開發過程中,已經登錄的情況下,調用支付寶授權登錄介面,也會報【40002 – 無效的AppID參數】。authrization_code 是第一次申請使用的,結果也用不了。

支付寶的開發平臺的資料是很亂的,你往往找appid是賬號中心才能找到的。然找 api 介面功能變數名稱,又要在介面文檔以外的某個點才能找到。抖音的都是直接在當前介面就找到響應API網關功能變數名稱了。完美詮釋了什麼叫做 A litter copy is better 。然後支付寶首頁或者開發者文檔,沒有社區快捷鏈接。搜索40002的時候,找不到社區,還是在其他搜索引擎搜索,才找到社區的入口。等找到入口時,就有開始新一輪的掃碼登錄。

 

uni-app以及開發的問題

開發不相容細節, 還很多。像 MySQL8.0 問題和 docker 疑難問題 也是開發過程中必須自己解決的自建伺服器問題。
還有些問題則是小程式平臺相容問題,比如:

各平臺儘管都是基於 oauth 2.0 來授權,但是不同平臺 authrization_code 和 access_token 有效期不一樣。而 session_key 的長度也不一樣。如果需要獲取手機號,又是分門別派的。

開發環境問題。

比如在支付寶的沙箱環境,調用會報 【報40002 – 無效的AppID參數】 的錯誤。參數無論多了還是少了,都會驗簽失敗。這個我有很深的印象,這種驗簽結果只有一門語言叫 Java 開發的 API 遇到過。我很納悶,這樣的話,介面如果需要擴展或者收縮,豈不是所有調用者都要跟著一起改?加密方法整的挺複雜的,調試過程中一直報 【crypto4go: certificate failed to load】。

一個平臺的oauth2.0流程示意圖

百度智能小程式,需要特別註意。百度引入靜態圖片資源不支持絕對路徑。只能用相對路徑。

使用百度開發者工具的bug 比較多,他的開發者工具要有兩個掃碼的登錄的地方的,還有比較坑的是:

百度開發者工具bug

這裡也是沒辦法,只能救助於社區。社區顯示,這個問題早在2019年就已經有人提過,2022年也有人重現。現在2023年了,我在最新版百度開發者工具也遇到了雷同的 Bug 報錯。

早先百度智能小程式是支持 uni-app 的 uni.login 調用的 swan.login。但後來他搞出來一個 getLoginCode 替代了前者。必須改為 【非 web-view 組件場景下登錄請使用 button 組件或聯合登錄 / 手機號授權登錄方式實現登錄,獲取登錄憑證請使用 swan.getLoginCode 實現。】了。

智能小程式不相容uni.login

 

前一陣,我是跟Rust 編譯器作鬥爭,最近很多時候,我都在跟幾個不同平臺的開發者工具作混戰。百度智能者小程式的登錄相關的前端代碼,是我最難調的一個平臺。它似乎自成一體,獨闢蹊徑,走了一條其他小程式平臺截然不同的道路。它出的問題是最多的。

多端小程式審核問題

做小程式,審核問題幾乎貫穿整個周期。從申請appid、寫基礎信息(百度的logo有特殊尺寸和形狀限制,支付寶的基礎信息拉下來三頁多到像是湊KPI一樣),最後來到能來到小程式版本審核的這扇巨大門口,都是非凡的成就了。期間可謂費勁九牛二虎之力,百感交集。當你本以為發佈就起飛的時候,往往這時候生活要給你來上當頭一棒,審核失敗!您給我回去修改您咧,走你!


支付寶代碼審核:沒有接入登錄邏輯時,支付寶代碼審核通過,但是什麼接入審核不通過。沒想明白,有可能是支付寶認為起名小程式不適用在支付寶小程式生態。後來間隔一周打來兩次電話,第一次說了下審核結果不通過,介面調用空白;第二次咨詢了一下我的小程式是用於什麼場景的,我的小程式審核是又通過了。我去後臺看下,沒法上架。作罷。

抖音對起名小程式違規。其實我已經接入了抖音官方的 antidirt 內容安全檢測,但是審核的時候還是,審核那邊不知是出Bug還是疏漏了,總之還是報【小程式文字上傳板塊未做風險詞以及風險內容過濾,不符合平臺要求,請補充信息安全防護能力或接入平臺內容安全檢測介面,詳見下方指引鏈接中9.5板塊】。後來第二次找客服,把我列印的日誌截圖發過去了。

另外,小logo的製作也需要圖片檢測,圖片安全加了之後,發現 chatGPT 生成的圖片地址,沒法從抖音那邊下載。那沒辦法了,生成logo 這塊功能就沒法上線了。

uni-app跨平臺開發小程式(抖音審核結果)

百度智能小程式認為起名小程式只有一個起名的功能,功能單一,所以沒有通過審核。

快手頭三次審核速度都挺快的,仔細列了不相容機型,一開始的小程式簡介和作用與實際不符,然後提交沒響應。一一改了,重新提交。

uni-app跨平臺開發小程式(快手審核結果)

QQ 連續多次提交都是是吧。審核失敗無原因。QQ社區沉悶,並米有什麼技術或客服響應問題。

uni-app開發跨平臺小程式開發的諸多坑uni-app跨平臺開發小程式(QQ審核結果)

想發版本?先猜測一下審核失敗的原因吧,然後改了,繼續掃碼提交審核。接二連三的打回再提申之後,驀然發覺好些天過去了。你依舊需要猜測它到底審核了什麼?是誰呢沒原因?我試試?我到底在哪裡?
QQ小程式審核他的時間就是個薛定諤的貓,你壓根不知道他在什麼時候會進行審核(2天起步),又在什麼地方給你不知道什麼審核原因的情況下打。另外你跑到社區問也沒用,那裡沒人回覆的,最早的回覆還是去年的。

 

開發小程式過程中掃碼這個事

我沒完全統計,每天如果每個平臺都需要發版的話,保守估計,反覆掃二維碼的次數需要不低於 30 次。微信、QQ、支付寶的登錄時間會很快失效,所以需要天天很高頻率掃碼登錄。尤其支付寶,幾分鐘就強制失效,你要用功能,重新掃登錄,否則請出門左轉。快速失效,確實是一種安全策略,唯有快速失效,可保賬號安全?還有就是支付寶小程式裡面你要跳來跳去的,經常找不到東西,哈哈哈哈~~

從開發的體驗來說,web > 小程式開發效率,移動端還沒上過真是的應用還不知道具體審核會怎麼樣。因為 web 端發佈快,可以快速迭代。如果真的要上小程式端,不管處於獲客還是贏得流量,引流等考慮,小程式端作為最後一個節點來處理比較好。無論如何,web 端可以最快出版本。目前還是有優勢。

個人小程式開髮結論

就挑一個平臺,比如微信小程式在這一個平臺。為什麼是它?以為它目前是市面上所有的小程式的開山鼻祖。先把所有的功能,你包括設計功能、UI佈局、性能全給他弄好了。尤其包括底部 tab !我記得有一次QQ提審時,報過一次審核不通過理由:QQ底部 tab 至少三個!而且他們的測試審核的時候,會掃你沒有展示出來頁面!也就是說,有些頁面你沒用到的,最好刪掉。

要有一個比較良好的心態,做小程式心態平和真的特別重要。特別一開始做的時候,需要充當開發者工具和第三方API的測試小白鼠。遇到問題,及時找出現問題的平臺社區進行反饋,能截圖儘量截圖(在保護敏感信息的前提下),提高處理問題的效率。畢竟有些問題不是出在你自身代碼上,你著急也沒有用。
面對審核的周期,要有一個預期:他們不會很快審核到你的。不要乾等,儘量先忙自己其他的事情。怎麼調整自己的焦慮心態,找些事情做,讓自己有意義的忙起來,就會減少自己的焦慮感。

QQ審核結果明細

在這個基礎上,再根據成熟度、流量、難易程度逐一佈局到其他的目標平臺(抖音、快手、QQ),最後再遷移到次優先順序(百度、支付寶、京東、小紅書)等平臺。每個平臺都有自己獨特的優勢和潛力,以及特殊性。

我記錄的比較瑣碎,開發過程中遇到以及已經解決和沒解決的問題,只多不少。一路走來,finally! 然後我的微信小程式\支付寶小程式\百度智能小程式【十倍網路工作室】已經上線了。
首頁功能目前只有兩個小功能繪製 logo 和起名字。後續將會推出更多更優質的模塊功能!

十倍網路工作室首頁 微信小程式 – 十倍網路工作室 支付寶小程式 – 十倍網路工作室
-- 原文 https://www.gitvim.com/uni-app%e5%bc%80%e5%8f%91%e8%b7%a8%e5%b9%b3%e5%8f%b0%e5%b0%8f%e7%a8%8b%e5%ba%8f%e5%bc%80%e5%8f%91%e7%9a%84%e8%af%b8%e5%a4%9a%e5%9d%91/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 硬體功耗測試 一、簡介 測試硬體的時候,避免不了功耗測試,功耗測試一般分為2種 第一個是被測硬體板子各個模組功耗情況 第二個是被測硬體整體功耗 為什麼要做功耗測試? 因為有些硬體產品是安裝電池的,一些低功耗產品比如感測器、車鑰匙等,安裝的都是紐扣電池,一節紐扣電池大概在600mAh左右,設備在安裝一 ...
  • 一:硬碟存儲 1、存儲類型 根據存儲的特性不同,可以將存儲分為記憶體和外存兩類。 記憶體:又叫做主存儲器,電腦中所有程式的運行都是在記憶體中進行。 外存:又叫做輔助存儲器,因為記憶體容量小且斷電會丟失所有數據。所以磁碟來實現數據的持久化存儲。例如:硬碟,U盤,軟盤,光碟 2、硬碟和磁碟: 磁碟是一個廣泛的 ...
  • linux伺服器預設通過22埠用ssh協議登錄,這種不安全。今天想做限制,即允許部分來源ip連接伺服器。 案例目標:通過iptables規則限制對linux伺服器的登錄。 處理方法:編寫為sh腳本,以便多次執行。iptables.sh : iptables -I INPUT -p tcp --dp ...
  • 一、單表查詢 庫表student.report,有3個欄位, 姓名、 學科、 成績, 記錄如下, 根據要求完成SQL語句 | Name | Subject | Result | | | | | | 李白 | Math | 95 | | 杜甫 | English | 83 | | 李商隱 | Math ...
  • 資料庫安裝方式:通用二進位安裝 策略1:直接拷貝資料庫文件 步驟1:主伺服器上停用資料庫 [root@node01 ~]# systemctl stop mysqld.service 步驟2:進入數據目錄,打包並壓縮數據文件 [root@node01 ~]# cd /usr/local/mysql/ ...
  • MySQL資料庫的安裝 (如果安裝失敗請看鏈接https://www.cnblogs.com/seeyouone/p/17236660.html) 註意: 必須用系統管理員身份運行mysql安裝程式。 安裝目錄切記不要用中文。 步驟一:雙擊mysql8的安裝嚮導 步驟二:安裝 (1)如果是首次安裝m ...
  • 步驟一:軟體的卸載準備 學習網路編程時,TCP/IP協議程式有伺服器端和客戶端。mysql這個資料庫管理軟體是使用TCP/IP協議。我們現在要卸載的是mysql的伺服器端,它沒有界面。 【計算】-->右鍵-->【管理】-->【服務】-->【mysql的服務】-->【停止】 步驟二:軟體的卸載 方式一 ...
  • 重要的話先說,今晚(3月20日)19:30 gt-checksum新版本發佈會,點擊下麵的鏈接預約: 會議詳情 (tencent.com) gt-checksum 1.2.0版本發佈後,受到了廣大社區用戶的熱烈響應。短短幾天,便有幾十個star,以及社區用戶提交了十幾條issue反饋問題,更有熱心用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...