


Le développement d'applications multiplateformes Uni-App réalise une mise à niveau des ressources en ligne
Cet article vous apporte des connaissances pertinentes sur uniapp. Il présente principalement comment réaliser la mise à niveau des ressources en ligne et les problèmes liés aux mises à jour à chaud. Utilisez uni-app pour développer des applications multi-terminaux et compiler le code sur iOS, Android, lors de la mise à niveau de plates-formes telles. en tant que mini-programmes WeChat, vous devez également envisager des mises à niveau simultanées multiplateformes. J'espère que cela sera utile à tout le monde.
Recommandé : "Tutoriel vidéo uniapp"
1 Préface
Utilisez uni-app
pour développer des applications multi-terminaux, et le code peut être compilé sur iOS.
, Android
, applet WeChat et autres plates-formes lors de la mise à niveau, vous devez également envisager des mises à niveau simultanées multiplateformes. Parmi eux, le mode de mise à niveau de uni-app
publié sous forme de mini-programme est relativement simple. Il vous suffit de soumettre le code développé au backend du mini-programme, et les utilisateurs seront automatiquement mis à niveau après approbation. uni-app
开发跨终端应用,可将代码编译到iOS
、Android
、微信小程序等多个平台,升级时也需考虑多平台同步升级。其中,uni-app
发布为小程序的升级模式较简单,只需将开发完的代码提交小程序后台,待审核通过后用户将自动升级。
HBuilderX 1.6.5
起,uni-app
支持生成 App
资源升级包wgt
。
二、wgt 资源升级包升级
2.1 修改版本号
首先,更新 manifest.json
中的版本号。
比如之前是 1.0.0
,那么新版本应该是 1.0.1
或 1.1.0
这样。
2.2 发行
然后,在 HBuilderX
中生成升级包(wgt
)。
菜单->发行->原生App-制作移动App资源升级包
生成结束会在控制台告知升级包的输出位置。
2.3 安装资源升级包
应用的升级需要服务端与客户端配合完成,下面以本地测试过程中的操作举例说明:
存放资源
将 %appid%.wgt
文件存放在服务器的 static
目录下,即 http://www.example.com/static/UNI832D722.wgt
。
服务端接口
约定检测升级的接口,地址为:http://www.example.com/update/
传入参数
-
name
String ‘’ 客户端读取到的应用名称,定义这个参数可以方便多个应用复用接口。 -
version
String ‘’ 客户端读取到的版本号信息
返回参数
-
update
Boolean false 是否有更新 -
wgtUrl
Stringwgt
包的下载地址,用于wgt
方式更新。 -
pkgUrl
Stringapk/ipa
包下载地址或AppStore
地址,用于整包升级的方式。
2.3.1 代码示例
下面是一个简单的服务端判定的示例,仅做参考,实际开发中根据自身业务需求处理。
var express = require('express'); var router = express.Router(); var db = require('./db'); // TODO 查询配置文件或者数据库信息来确认是否有更新 function checkUpdate(params, callback) { db.query('一段SQL', function(error, result) { // 这里简单判定下,不相等就是有更新。 var currentVersions = params.appVersion.split('.'); var resultVersions = result.appVersion.split('.'); if (currentVersions[0] <p>注意事项</p>
- 服务端的具体判定逻辑,请根据自身的业务逻辑灵活处理。
- 应用中的路径尽量不要包含特殊符号。
客户端检测升级
在 App.vue
的 onLaunch
中检测升级,代码如下:
// #ifdef APP-PLUS plus.runtime.getProperty(plus.runtime.appid, function(widgetInfo) { uni.request({ url: 'http://www.example.com/update/', data: { version: widgetInfo.version, name: widgetInfo.name }, success: (result) => { var data = result.data; if (data.update && data.wgtUrl) { uni.downloadFile({ url: data.wgtUrl, success: (downloadResult) => { if (downloadResult.statusCode === 200) { plus.runtime.install(downloadResult.tempFilePath, { force: false }, function() { console.log('install success...'); plus.runtime.restart(); }, function(e) { console.error('install fail...'); }); } } }); } } }); }); // #endif
不支持资源升级包情况如下:
-
SDK
部分有调整,比如新增了Maps
模块等,不可通过此方式升级,必须通过整包的方式升级。 - 原生插件的增改,同样不能使用此方式。
- 对于老的非自定义组件编译模式,这种模式已经被淘汰下线。但以防万一也需要说明下,老的非自定义组件编译模式,如果之前工程没有
nvue
文件,但更新中新增了nvue
文件,不能使用此方式。因为非自定义组件编译模式如果没有nvue
文件是不会打包weex
引擎进去的,原生引擎无法动态添加。自定义组件模式默认就含着weex
引擎,不管工程下有没有nvue
À partir de
HBuilderX 1.6.5
, uni-app
prend en charge la génération du package de mise à niveau des ressources App
wgt
. 2. Mise à niveau du package de mise à niveau des ressources Wgt2.1 Modifier le numéro de version
Tout d'abord, mettez à jour le numéro de version dans manifest.json
.
Par exemple, s'il s'agissait de 1.0.0
auparavant, alors la nouvelle version devrait être 1.0.1
ou 1.1.0
.
2.2 Release
🎜Ensuite, générez le package de mise à niveau (wgt
) dans HBuilderX
. 🎜{ "appid": plus.runtime.appid, "version": plus.runtime.version }

Générer à à la fin, l'emplacement de sortie du package de mise à niveau sera informé sur la console.

2.3 Installez le package de mise à niveau des ressources
🎜La mise à niveau de l'application nécessite la coopération du serveur et du client. Voici un exemple de l'opération lors du processus de test local : 🎜🎜🎜Stockage des ressources🎜Remplacez
http://www.example.com/static/UNI832D722.wgt
. 🎜🎜🎜Interface serveur🎜Acceptée pour détecter l'interface de mise à niveau, l'adresse est :
http://www.example.com/update/
🎜🎜🎜Paramètres entrants🎜🎜-
name
String '' Le nom de l'application lu par le client La définition de ce paramètre peut faciliter la réutilisation de l'interface par plusieurs applications. 🎜 -
version
String '' Les informations sur le numéro de version lues par le client🎜🎜🎜🎜Paramètres de retour🎜🎜-
update
Booléen false Y en a-t-il Update🎜 -
wgtUrl
String Adresse de téléchargement du packagewgt
, utilisée pour la mise à jour dewgt
. 🎜 -
pkgUrl
String Adresse de téléchargement du packageapk/ipa
ou adresseAppStore
, utilisée pour la mise à niveau complète du package. 🎜🎜2.3.1 Exemple de code
🎜Ce qui suit est un exemple simple de détermination côté serveur. Il est à titre de référence uniquement. Dans le développement réel, il sera traité en fonction des besoins de votre propre entreprise. 🎜🎜Notes🎜{ "status":1,//升级标志,1:需要升级;0:无需升级 `在这里插入代码片` "note": "修复bug1;\n修复bug2;",//release notes "url": "http://www.example.com/uniapp.apk" //更新包下载地址 }
Copier après la connexionCopier après la connexion- Veuillez gérer la logique de jugement spécifique du serveur de manière flexible en fonction de votre propre logique métier. 🎜
- Essayez de ne pas inclure de symboles spéciaux dans le chemin de l'application. 🎜🎜🎜Le client détecte les mises à niveau
Détecte les mises à niveau dansonLaunch
deApp.vue
Le code est le suivant : 🎜🎜🎜La situation dans laquelle se trouvent les packages de mise à niveau de ressources. non supporté est le suivant : 🎜🎜onLaunch: function () { //#ifdef APP-PLUS var server = "https://www.example.com/update"; //检查更新地址 var req = { //升级检测数据 "appid": plus.runtime.appid, "version": plus.runtime.version }; uni.request({ url: server, data: req, success: (res) => { if (res.statusCode == 200 && res.data.status === 1) { uni.showModal({ //提醒用户更新 title: "更新提示", content: res.data.note, success: (res) => { if (res.confirm) { plus.runtime.openURL(res.data.url); } } }) } } }) //#endif }
Copier après la connexionCopier après la connexion- La partie
SDK
a été ajustée, comme l'ajout du moduleMaps
, etc. Elle ne peut pas être mise à niveau via cette méthode et doit être mis à niveau via l’ensemble du package. 🎜 - Cette méthode ne peut pas être utilisée pour les ajouts et modifications de plug-ins natifs. 🎜
- Pour l'ancien mode de compilation de composants non personnalisés, ce mode a été supprimé. Mais juste au cas où, je dois expliquer que dans l'ancien mode de compilation de composants non personnalisés, si le projet précédent n'avait pas de fichier
nvue
, mais un nouveau fichiernvue
a été ajouté dans la mise à jour, cela ne fonctionnera pas. Utilisez cette méthode. Parce que le mode de compilation des composants non personnalisés ne conditionnera pas le moteurweex
sans le fichiernvue
et que le moteur natif ne peut pas être ajouté dynamiquement. Le mode composant personnalisé inclut le moteurweex
par défaut, qu'il existe ou non un fichiernvue
sous le projet. 🎜🎜🎜🎜Notes🎜🎜- 条件编译,仅在
App
平台执行此升级逻辑。 -
appid
以及版本信息等,在HBuilderX
真机运行开发期间,均为HBuilder
这个应用的信息,因此需要打包自定义基座或正式包测试升级功能。 -
plus.runtime.version
或者uni.getSystemInfo()
读取到的是apk/ipa
包的版本号,而非manifest.json
资源中的版本信息,所以这里用plus.runtime.getProperty()
来获取相关信息。 - 安装
wgt
资源包成功后,必须执行plus.runtime.restart()
,否则新的内容并不会生效。 - 如果
App
的原生引擎不升级,只升级wgt
包时需要注意测试wgt
资源和原生基座的兼容性⚠️。平台默认会对不匹配的版本进行提醒,如果自测没问题,可以在manifestt.json
中配置忽略提示。 - 应用市场为了防止开发者不经市场审核许可,给用户提供违法内容,对热更新大多持排斥态度。
但实际上热更新使用非常普遍,不管是原生开发中还是跨平台开发。
Apple
曾经禁止过jspatch
,但没有打击其他的热更新方案,包括cordovar、react native、DCloud
。封杀jspatch
其实是因为jspatch
有严重安全漏洞,可以被黑客利用,造成三方黑客可篡改其他App
的数据。使用热更新需要注意:
- 上架审核期间不要弹出热更新提示;
- 热更新内容使用
https
下载,避免被三方网络劫持; - 不要更新违法内容、不要通过热更新破坏应用市场的利益,比如
iOS
的虚拟支付要老老实实给Apple
分钱。
三、整包升级
接口约定
如下数据接口约定仅为示例,开发者可以自定义接口参数。请求地址:
https://www.example.com/update
请求方法:
GET
请求数据:
{ "appid": plus.runtime.appid, "version": plus.runtime.version }
Copier après la connexionCopier après la connexion响应数据:
{ "status":1,//升级标志,1:需要升级;0:无需升级 `在这里插入代码片` "note": "修复bug1;\n修复bug2;",//release notes "url": "http://www.example.com/uniapp.apk" //更新包下载地址 }
Copier après la connexionCopier après la connexion3.1 客户端实现
App
启动时,向服务端上报当前版本号,服务端判断是否提示升级。在
App.vue
的onLaunch
中,发起升级检测请求,如下:onLaunch: function () { //#ifdef APP-PLUS var server = "https://www.example.com/update"; //检查更新地址 var req = { //升级检测数据 "appid": plus.runtime.appid, "version": plus.runtime.version }; uni.request({ url: server, data: req, success: (res) => { if (res.statusCode == 200 && res.data.status === 1) { uni.showModal({ //提醒用户更新 title: "更新提示", content: res.data.note, success: (res) => { if (res.confirm) { plus.runtime.openURL(res.data.url); } } }) } } }) //#endif }
Copier après la connexionCopier après la connexion注意:
App
的升级检测代码必须使用条件编译,否则在微信环境由于不存在plus
相关API
,将会报错。3.2 数据表实现
需维护一张数据表,用于维护
APP
版本信息,主要字段信息如下:字段名称 数据类型 数据说明 AppID
varchar
mobile AppID version
varchar
应用市场版本号 notes
varchar
版本更新说明 url
varchar
应用市场下载URL。 注意:根据谷歌、App Store应用市场审核规范,应用升级只能通过提交应用市场更新,不能通过下载 apk
、IPA
安装方式更新应用。3.3 服务端实现
根据客户端接收的版本号,比对服务端最新版本号,决定是否需要升级,若需升级则返回升级信息(
rlease notes
、更新包地址
等)开发者可以根据服务端开发语言,自己实现升级检测逻辑,如下是一个
php
示例代码:header("Content-type:text/json"); $appid = $_GET["appid"]; $version = $_GET["version"]; //客户端版本号 $rsp = array("status" => 0); //默认返回值,不需要升级 if (isset($appid) && isset($version)) { if ($appid === "__UNI__123456") { //校验appid if ($version !== "1.0.1") { //这里是示例代码,真实业务上,最新版本号及relase notes可以存储在数据库或文件中 $rsp["status"] = 1; $rsp["note"] = "修复bug1;\n修复bug2;"; //release notes $rsp["url"] = "http://www.example.com/uniapp.apk"; //应用升级包下载地址 } } } echo json_encode($rsp); exit;
Copier après la connexion注意事项:
-
plus.runtime.appid
,plus.runtime.version
,plus.runtime.openURL()
在真机环境下才有效。 - 版本检测需要打包
app
,真机运行基座无法测试。因为真机运行的plus.runtime.version
是固定值。 - 根据谷歌应用市场的审核规范,应用升级只能通过提交应用市场更新,不能通过下载
apk
安装方式更新应用。apk
安装失败可能是因为缺少android.permission.INSTALL_PACKAGES
、android.permission.REQUEST_INSTALL_PACKAGES
权限导致,注意:添加上面两个权限无法通过谷歌审核。
四、Uni-app 版本升级中心
uni-app
提供了一整套版本维护框架,包含升级中心uni-upgrade-center - Admin
、前台检测更新uni-upgrade-center-app
。4.1 升级中心 uni-upgrade-center - Admin
uni-app
提供了版本维护后台应用升级中心uni-upgrade-center - Admin
,升级中心是一款uni-admin
插件,负责App
版本更新业务。包含后台管理界面、更新检查逻辑,App
内只要调用弹出提示即可。
在上传安装包界面填写此次发版信息,其中包地址可以选择手动上传一个文件到云存储,会自动将地址填入该项。也可以手动填写一个地址(例如:https://appgallery.huawei.com/app/C10764638),就可以不用再上传文件。
如果是发布苹果版本,包地址则为应用在
AppStore
的链接。
升级中心有以下功能点:- 云储存安装包
CDN
加速,使安装包下载的更快、更稳定 - 应用管理,对
App
的信息记录和应用版本管理。 - 版本管理,可以发布新版,也可方便直观的对当前
App
历史版本以及线上发行版本进行查看、编辑和删除操作。 - 版本发布信息管理,包括更新标题,内容,版本号,静默更新,强制更新,灵活上线发行的设置和修改。
- 原生
App
安装包,发布Apk
更新,用于App
的整包更新,可设置是否强制更新。 -
wgt
资源包,发布wgt
更新,用于App
的热更新,可设置是否强制更新,静默更新。 - App管理列表及App版本记录列表搜索。
- 只需导入插件,初始化数据库即可拥有上述功能。
- 也可以自己修改逻辑自定义数据库字段,和随意定制 UI 样式。
4.2 前台检测更新 uni-upgrade-center-app
uni-upgrade-center-app
负责前台检查升级更新。项目结构如下图所示:
检测更新视图如下图所示:
该插件提供如下功能:- Gestion unifiée de
App
etApp
sur les plateformesAndroid
etiOS
App
Publication et mise à niveau des packages d'installation et des packages de ressourceswgt
.App
及App
在Android
、iOS
平台上App
安装包和wgt
资源包的发布升级。 - 基于
uni-upgrade-center
一键式检查更新,统一整包与wgt
Basé sur - Complétez la vérification en fonction des paramètres transmis pour déterminer quelle méthode utiliser pour cette mise à jour.
- Mise à niveau en un clic. Des logiques telles que des boîtes pop-up, des téléchargements, des installations, des redémarrages forcés, etc. ont été intégrées.
- Si le téléchargement est terminé et la mise à niveau est annulée, le package d'installation sera automatiquement mis en cache la prochaine fois que vous le saisirez, il sera jugé s'il répond aux conditions d'installation. Si le jugement échoue, il sera automatiquement effacé.
- Beau, pratique et personnalisable.
uni-upgrade-center
, vérification des mises à jour en un clic, unifiant l'ensemble du package et les mises à jour du package de ressourceswgt
.Remarque : Le numéro de version et le appid obtenus lors de l'exécution sur la base du téléphone mobile sont les versions de hbuilder et hbuilder
et doivent être définis manuellement dans le fichier. 4.3 Principe de fonctionnement
Le plug-in de détection et de mise à jour frontale uni-upgrade-center-app est chargé de fournir une vérification et une mise à jour en un clic en appelant les fonctions cloud pour lire les informations de version conservées par la base de données.
Centre de mise à niveau uni-upgrade-center - L'administrateur est responsable de la maintenance des informations de version et de la maintenance des informations de version dans la base de données.Recommandé : "tutoriel uniapp
"🎜 - 条件编译,仅在
- La partie
-
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Étapes pour lancer l'aperçu du projet UniApp dans WebStorm : Installer le plugin UniApp Development Tools Se connecter aux paramètres de l'appareil Aperçu du lancement de WebSocket

De manière générale, uni-app est préférable lorsque des fonctions natives complexes sont nécessaires ; MUI est meilleur lorsque des interfaces simples ou hautement personnalisées sont nécessaires. De plus, uni-app possède : 1. Prise en charge de Vue.js/JavaScript ; 2. Composants/API natifs riches 3. Bon écosystème ; Les inconvénients sont : 1. Problèmes de performances ; 2. Difficulté à personnaliser l'interface ; MUI a : 1. Prise en charge de la conception matérielle ; 2. Grande flexibilité ; 3. Bibliothèque étendue de composants/thèmes. Les inconvénients sont : 1. Dépendance CSS ; 2. Ne fournit pas de composants natifs ; 3. Petit écosystème ;

UniApp utilise HBuilder

Le développement d'Uniapp nécessite les bases suivantes : technologie front-end (HTML, CSS, JavaScript) connaissance du développement mobile (plateformes iOS et Android) autres bases de Node.js (outils de contrôle de version, IDE, simulateur de développement mobile ou expérience réelle du débogage machine)

UniApp présente de nombreux avantages en tant que cadre de développement multiplateforme, mais ses inconvénients sont également évidents : les performances sont limitées par le mode de développement hybride, ce qui entraîne une vitesse d'ouverture, un rendu des pages et une réponse interactive médiocres. L'écosystème est imparfait et il existe peu de composants et de bibliothèques dans des domaines spécifiques, ce qui limite la créativité et la réalisation de fonctions complexes. Les problèmes de compatibilité sur différentes plates-formes sont sujets à des différences de style et à une prise en charge incohérente des API. Le mécanisme de sécurité de WebView est différent de celui des applications natives, ce qui peut réduire la sécurité des applications. Les versions et mises à jour d'applications prenant en charge plusieurs plates-formes en même temps nécessitent plusieurs compilations et packages, ce qui augmente les coûts de développement et de maintenance.

Lorsque vous choisissez entre UniApp et le développement natif, vous devez prendre en compte le coût de développement, les performances, l'expérience utilisateur et la flexibilité. Les avantages d'UniApp sont le développement multiplateforme, l'itération rapide, l'apprentissage facile et les plug-ins intégrés, tandis que le développement natif est supérieur en termes de performances, de stabilité, d'expérience native et d'évolutivité. Pesez le pour et le contre en fonction des besoins spécifiques du projet. UniApp convient aux débutants, et le développement natif convient aux applications complexes qui recherchent des performances élevées et une expérience transparente.

UniApp est basé sur Vue.js et Flutter est basé sur Dart. Les deux prennent en charge le développement multiplateforme. UniApp fournit des composants riches et un développement facile, mais ses performances sont limitées par WebView ; Flutter utilise un moteur de rendu natif, qui offre d'excellentes performances mais est plus difficile à développer. UniApp possède une communauté chinoise active et Flutter possède une communauté vaste et mondiale. UniApp convient aux scénarios avec un développement rapide et de faibles exigences de performances ; Flutter convient aux applications complexes avec une personnalisation élevée et des performances élevées.

Bibliothèque de composants recommandée pour Uniapp afin de développer de petits programmes : uni-ui : officiellement produite par Uniapp, elle fournit des composants de base et métier. vant-weapp : produit par Bytedance, avec une conception d'interface utilisateur simple et esthétique. taro-ui : produit par JD.com et développé sur la base du framework Taro. fish-design : produit par Baidu, en utilisant le style de conception Material Design. naive-ui : produit par Youzan, conception d'interface utilisateur moderne, légère et facile à personnaliser.
