uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현

WBOY
풀어 주다: 2022-02-28 18:00:39
앞으로
3866명이 탐색했습니다.

이 기사에서는 uniapp에 대한 관련 지식을 제공합니다. 주로 uni-app을 사용하여 크로스 터미널 애플리케이션을 개발하고 코드를 iOS, Android, When에 컴파일할 수 있는 방법을 소개합니다. WeChat 미니 프로그램과 같은 플랫폼을 업그레이드하려면 다중 플랫폼 동시 업그레이드도 고려해야 합니다. 이것이 모든 사람에게 도움이 되기를 바랍니다.

uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현

추천: "uniapp 비디오 튜토리얼"

1. 소개

uni-app을 사용하여 크로스 터미널 애플리케이션을 개발하고 코드를 iOS로 컴파일할 수 있습니다. , Android, WeChat 애플릿 및 기타 플랫폼 업그레이드 시 다중 플랫폼 동시 업그레이드도 고려해야 합니다. 그 중 미니 프로그램으로 출시된 uni-app의 업그레이드 모드는 비교적 간단합니다. 개발된 코드를 미니 프로그램 백엔드에 제출하기만 하면 사용자가 승인 후 자동으로 업그레이드됩니다. uni-app 开发跨终端应用,可将代码编译到iOSAndroid、微信小程序等多个平台,升级时也需考虑多平台同步升级。其中,uni-app发布为小程序的升级模式较简单,只需将开发完的代码提交小程序后台,待审核通过后用户将自动升级。

HBuilderX 1.6.5 起,uni-app 支持生成 App 资源升级包wgt

二、wgt 资源升级包升级

2.1 修改版本号

首先,更新 manifest.json 中的版本号。
比如之前是 1.0.0,那么新版本应该是 1.0.11.1.0 这样。
uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현

2.2 发行

然后,在 HBuilderX 中生成升级包(wgt)。

菜单->发行->原生App-制作移动App资源升级包
로그인 후 복사

uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현
生成结束会在控制台告知升级包的输出位置。
uni-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 String wgt 包的下载地址,用于 wgt 方式更新。
  • pkgUrl String apk/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.vueonLaunch 中检测升级,代码如下:

// #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
  • HBuilderX 1.6.5부터 uni-app 리소스 업그레이드 패키지 wgt 생성을 지원합니다.

2.Wgt 리소스 업그레이드 패키지 업그레이드

2.1 버전 번호 수정

먼저 manifest.json에서 버전 번호를 업데이트하세요.
예를 들어 이전에 1.0.0이었다면 새 버전은 1.0.1 또는 1.1.0이어야 합니다.
여기에 이미지 설명 삽입

2.2 Release

🎜그런 다음 HBuilderX에서 업그레이드 패키지(wgt)를 생성하세요. 🎜
{  
    "appid": plus.runtime.appid,  
    "version": plus.runtime.version  
}
로그인 후 복사
로그인 후 복사
🎜여기에 이미지 설명 삽입
생성 위치 마지막에는 업그레이드 패키지의 출력 위치가 콘솔에 알려집니다.
여기에 이미지 설명 삽입🎜

2.3 리소스 업그레이드 패키지 설치

🎜 애플리케이션을 업그레이드하려면 서버와 클라이언트의 협력이 필요합니다. 다음은 로컬 테스트 프로세스 중 작업의 예입니다. 🎜🎜🎜리소스 저장🎜
교체 %appid% .wgt 파일은 서버의 static 디렉토리, 즉 http://www.example.com/static/UNI832D722.wgt에 저장됩니다. . 🎜🎜🎜서버 인터페이스🎜
업그레이드 인터페이스를 감지하는 데 동의했습니다. 주소는 http://www.example.com/update/🎜🎜🎜수신 매개변수🎜🎜
    입니다.
  • name String '' 클라이언트가 읽는 애플리케이션 이름입니다. 이 매개변수를 정의하면 여러 애플리케이션에서 인터페이스를 쉽게 재사용할 수 있습니다. 🎜
  • version String '' 클라이언트가 읽은 버전 번호 정보🎜🎜🎜🎜Return 매개변수🎜🎜
    • update Boolean false 존재 여부 Update🎜
    • wgtUrl 문자열 wgt 패키지 다운로드 주소, wgt 업데이트에 사용됩니다. 🎜
    • pkgUrl 문자열 apk/ipa 패키지 다운로드 주소 또는 AppStore 주소, 전체 패키지 업그레이드에 사용됩니다. 🎜🎜2.3.1 코드 예시🎜 다음은 서버 측 판단에 대한 간단한 예시입니다. 실제 개발 시에는 비즈니스 요구 사항에 따라 처리됩니다. 🎜
      {  
          "status":1,//升级标志,1:需要升级;0:无需升级  `在这里插入代码片`    "note": "修复bug1;\n修复bug2;",//release notes  
          "url": "http://www.example.com/uniapp.apk" //更新包下载地址  
      }
      로그인 후 복사
      로그인 후 복사
      🎜Notes🎜
      • 서버의 구체적인 판단 로직은 본인의 비즈니스 로직에 맞춰 유연하게 처리해주세요. 🎜
      • 애플리케이션 경로에 특수 기호를 포함하지 마세요. 🎜🎜🎜클라이언트가 업그레이드를 감지
        App.vueonLaunch에서 업그레이드를 감지합니다. 코드는 다음과 같습니다. 🎜
        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  }
        로그인 후 복사
        로그인 후 복사
        🎜🎜리소스 업그레이드 패키지가 있는 상황 지원되지 않는 사항은 다음과 같습니다. 🎜🎜
        • 지도 모듈 추가 등 SDK 부분이 조정되었습니다. 업그레이드할 수 없습니다. 이 방법을 통해 전체 패키지를 통해 업그레이드해야 합니다. 🎜
        • 네이티브 플러그인에 대한 추가 및 수정에는 이 방법을 사용할 수 없습니다. 🎜
        • 기존 비맞춤형 구성요소 컴파일 모드의 경우 이 모드가 제거되었습니다. 하지만 만일을 대비해 기존의 비맞춤형 컴포넌트 컴파일 모드에서 이전 프로젝트에 nvue 파일이 없고 새로운 nvue 파일이 있는 경우에 대해 설명해야 합니다. 업데이트에 추가되었으므로 이 방법을 사용하지 마세요. 비사용자 정의 구성 요소 컴파일 모드는 nvue 파일 없이 weex 엔진을 패키징하지 않으며 기본 엔진을 동적으로 추가할 수 없기 때문입니다. 사용자 정의 구성 요소 모드에는 프로젝트 아래에 nvue 파일이 있는지 여부에 관계없이 기본적으로 weex 엔진이 포함됩니다. 🎜🎜🎜🎜메모🎜🎜
          • 条件编译,仅在 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" //更新包下载地址  
          }
          로그인 후 복사
          로그인 후 복사

          3.1 客户端实现

          App启动时,向服务端上报当前版本号,服务端判断是否提示升级。

          App.vueonLaunch中,发起升级检测请求,如下:

          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,将会报错。

          3.2 数据表实现

          需维护一张数据表,用于维护APP版本信息,主要字段信息如下:

          字段名称 数据类型 数据说明
          AppID varchar mobile AppID
          version varchar 应用市场版本号
          notes varchar 版本更新说明
          url varchar 应用市场下载URL。 注意:根据谷歌、App Store应用市场审核规范,应用升级只能通过提交应用市场更新,不能通过下载apkIPA安装方式更新应用。

          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;
          로그인 후 복사

          注意事项:

          • plus.runtime.appidplus.runtime.versionplus.runtime.openURL() 在真机环境下才有效。
          • 版本检测需要打包app,真机运行基座无法测试。因为真机运行的plus.runtime.version是固定值。
          • 根据谷歌应用市场的审核规范,应用升级只能通过提交应用市场更新,不能通过下载apk安装方式更新应用。apk安装失败可能是因为缺少android.permission.INSTALL_PACKAGESandroid.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内只要调用弹出提示即可。
          uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현
          在上传安装包界面填写此次发版信息,其中包地址可以选择手动上传一个文件到云存储,会自动将地址填入该项。

          也可以手动填写一个地址(例如:https://appgallery.huawei.com/app/C10764638),就可以不用再上传文件。

          如果是发布苹果版本,包地址则为应用在AppStore的链接。
          uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현
          升级中心有以下功能点:

          • 云储存安装包CDN加速,使安装包下载的更快、更稳定
          • 应用管理,对App的信息记录和应用版本管理。
          • 版本管理,可以发布新版,也可方便直观的对当前App历史版本以及线上发行版本进行查看、编辑和删除操作。
          • 版本发布信息管理,包括更新标题内容版本号,静默更新,强制更新,灵活上线发行的设置和修改。
          • 原生App安装包,发布Apk更新,用于App的整包更新,可设置是否强制更新。
          • wgt资源包,发布wgt更新,用于App的热更新,可设置是否强制更新,静默更新。
          • App管理列表及App版本记录列表搜索。
          • 只需导入插件,初始化数据库即可拥有上述功能。
          • 也可以自己修改逻辑自定义数据库字段,和随意定制 UI 样式。

          4.2 前台检测更新 uni-upgrade-center-app

          uni-upgrade-center-app 负责前台检查升级更新。

          项目结构如下图所示:
          uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현
          检测更新视图如下图所示:
          uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현
          该插件提供如下功能:

          • AndroidiOS 플랫폼 App에서 통합 관리 설치 패키지와 wgt 리소스 패키지를 출시하고 업그레이드합니다. AppAppAndroidiOS平台上App安装包和wgt资源包的发布升级。
          • 基于uni-upgrade-center一键式检查更新,统一整包与 wgt
          • uni-upgrade-center를 기반으로 한 번의 클릭으로 업데이트 확인, 전체 패키지 및 wgt 리소스 패키지 업데이트를 통합합니다.
          • 이 업데이트에 사용할 방법을 결정하려면 전달된 매개변수를 기반으로 확인을 완료하세요.
          • 원클릭 업그레이드. 팝업 상자, 다운로드, 설치, 강제 재시작 등의 로직이 통합되었습니다.
          • 다운로드가 완료되고 업그레이드가 취소되면 설치 패키지가 자동으로 캐시됩니다. 다음 번 입력 시 설치 조건 충족 여부를 판단하여 실패하면 자동으로 삭제됩니다.
          • 아름답고 실용적이며 맞춤 설정이 가능합니다.

          참고: 휴대폰 베이스에서 실행할 때 얻은 버전 번호appidhbuilderhbuilder

          버전이며 파일에서 수동으로 설정해야 합니다.

          4.3 작동 원리


          업그레이드 센터 uni-upgrade-center - 관리자는 버전 정보를 유지하고 데이터베이스의 버전 정보를 유지하는 일을 담당합니다.

          프런트 엔드 감지 및 업데이트 플러그인 uni-upgrade-center-app은 클라우드 기능을 호출하여 데이터베이스에서 유지 관리하는 버전 정보를 읽어 원클릭 확인 및 업데이트를 제공하는 역할을 합니다.

          추천: "uniapp 튜토리얼

          "🎜

위 내용은 uni-app 크로스 플랫폼 애플리케이션 개발로 온라인 리소스 업그레이드 실현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿