Artikel ini membawa anda pengetahuan yang berkaitan tentang uniapp terutamanya cara melaksanakan peningkatan dalam talian sumber dan isu berkaitan kemas kini yang hangat Menggunakan uni-app untuk membangunkan aplikasi merentas terminal, anda boleh menukar kod yang Disusun kepada iOS, Android, applet WeChat dan platform lain, anda juga perlu mempertimbangkan peningkatan serentak berbilang platform apabila menaik taraf saya harap ia akan membantu semua orang.
Disyorkan: "tutorial video uniapp"
, applet WeChat, dsb. Apabila menaik taraf, peningkatan berbilang platform serentak juga mesti dipertimbangkan. Antaranya, mod naik taraf uni-app
yang diterbitkan sebagai program mini adalah agak mudah Anda hanya perlu menyerahkan kod yang dibangunkan ke bahagian belakang program mini, dan pengguna akan dinaik taraf secara automatik selepas kelulusan. Bermula daripada iOS
Android
uni-app
,
pakej peningkatan sumber HBuilderX 1.6.5
. uni-app
App
2. Naik taraf pakej peningkatan sumber Wgt wgt
, maka versi baharu sepatutnya manifest.json
atau
seperti ini. 1.0.0
1.0.1
1.1.0
Keluaran 2.2
HBuilderX
wgt
菜单->发行->原生App-制作移动App资源升级包
2.3 Memasang pakej peningkatan sumber
Sumber storan
Simpan fail dalam direktori pelayan, iaitu
. %appid%.wgt
static
http://www.example.com/static/UNI832D722.wgt
Antara muka pelayan
Antara muka yang dipersetujui untuk mengesan peningkatan, alamatnya ialah: http://www.example.com/update/
Parameter masuk
String '' Nama aplikasi yang dibaca oleh klien Mentakrifkan parameter ini boleh memudahkan penggunaan semula antara muka oleh berbilang aplikasi.
name
Rentetan '' Maklumat nombor versi dibaca oleh klienversion
Boolean false Sama ada terdapat kemas kini
update
Rentetan wgtUrl
wgt
wgt
Rentetan pkgUrl
apk/ipa
AppStore
2.3.1 Contoh KodNota
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>Sila kendalikan logik penghakiman khusus pelayan secara fleksibel mengikut logik perniagaan anda sendiri. </p>
, kodnya adalah seperti berikut: 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
Terdapat beberapa pelarasan, seperti menambah
SDK
Tambahan dan perubahan pada pemalam asli tidak boleh digunakan dengan cara ini. Maps
nvue
dan enjin asli tidak boleh ditambah secara dinamik. Mod komponen tersuai termasuk enjin nvue
secara lalai, tidak kira sama ada terdapat fail nvue
di bawah projek. weex
weex
nvue
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 }
响应数据:
{ "status":1,//升级标志,1:需要升级;0:无需升级 `在这里插入代码片` "note": "修复bug1;\n修复bug2;",//release notes "url": "http://www.example.com/uniapp.apk" //更新包下载地址 }
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 }
注意:App
的升级检测代码必须使用条件编译,否则在微信环境由于不存在plus
相关API
,将会报错。
需维护一张数据表,用于维护APP
版本信息,主要字段信息如下:
字段名称 | 数据类型 | 数据说明 |
---|---|---|
AppID |
varchar |
mobile AppID |
version |
varchar |
应用市场版本号 |
notes |
varchar |
版本更新说明 |
url |
varchar |
应用市场下载URL。 注意:根据谷歌、App Store应用市场审核规范,应用升级只能通过提交应用市场更新,不能通过下载apk 、IPA 安装方式更新应用。 |
根据客户端接收的版本号,比对服务端最新版本号,决定是否需要升级,若需升级则返回升级信息(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;
注意事项:
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-upgrade-center - Admin
、前台检测更新uni-upgrade-center-app
。
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 样式。
uni-upgrade-center-app
负责前台检查升级更新。
项目结构如下图所示:
检测更新视图如下图所示:
该插件提供如下功能:
- Pengurusan bersepadu
App
danApp
keluaran dan naik tarafAndroid
pakej pemasangan daniOS
pakej sumber pada platformApp
danwgt
.- Berdasarkan
uni-upgrade-center
semakan satu klik untuk kemas kini, satukan keseluruhan pakej danwgt
kemas kini pakej sumber.- Lengkapkan pengesahan berdasarkan parameter yang diluluskan untuk menentukan kaedah yang hendak digunakan untuk kemas kini ini.
- Naik taraf satu klik. Logik seperti kotak pop timbul, muat turun, pemasangan, mula semula paksa, dll. telah disepadukan.
- Jika muat turun selesai dan naik taraf dibatalkan, pakej pemasangan akan dicache secara automatik Pada kali seterusnya anda memasukkannya, ia akan dinilai sama ada ia memenuhi syarat pemasangan Jika penghakiman gagal dibersihkan secara automatik.
- Cantik, praktikal dan boleh disesuaikan.
Nota: nombor versi dan appid yang diperoleh apabila dijalankan pada pangkalan telefon mudah alih ialah hbuilder dan Versi hbuilder perlu ditetapkan secara manual dalam fail.
Pusat Naik Taraf uni-upgrade-center - Pentadbir bertanggungjawab untuk mengekalkan maklumat versi dan mengekalkan maklumat versi ke dalam pangkalan data.
Pengesanan bahagian hadapan dan pengemaskinian pemalam uni-upgrade-center-app bertanggungjawab untuk menyediakan semakan dan kemas kini satu klik dengan memanggil fungsi awan untuk membaca maklumat versi yang diselenggara oleh pangkalan data.
Disyorkan: "tutorial uniapp"
Atas ialah kandungan terperinci pembangunan aplikasi merentas platform uni-app merealisasikan peningkatan sumber dalam talian. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!