主頁 > 企業開發 > uni-app開發跨平臺小程式開發的諸多坑【轉載】

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

2023-03-21 10:35:44 企業開發

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/

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/547535.html

標籤:JavaScript

上一篇:Ajax及其應用

下一篇:Three.js 進階之旅:物理效果-3D乒乓球小游戲 🏓

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more