文档

mPaaS 小程序扫码时提示“应用更新错误”

更新时间:

问题描述

App 扫码 mPaas 小程序弹出 Toast 信息:“应用更新错误(50002)”。

常见原因

通过扫码进行真机调试的正常流程如下:

  1. 在小程序 IDE 生成二维码,以供手机客户端扫描,同时会将小程序包上传至 mPaaS 控制台的小程序发布中。

  2. 手机客户端扫描此二维码后,会主动通过 RPC 请求去拉取控制台中的 AMR 文件。

当调用 MDS 小程序更新接口后,若没有获取对应的小程序信息,就会提示“应用更新错误(50002)”。

这类问题可能的原因包括:

  • 服务端尚未发布。

  • 控制台未发布上传的小程序。

  • 小程序刚发布,但服务端尚未收到刚发布的小程序。

  • 客户端版本不在范围内。

  • 请求信息和服务端发布的规则不匹配。

问题排查步骤

  1. 过滤日志。 在 Android Studio 控制台的日志信息中过滤关键字 DynamicRelease。查看 UnionResourceInfo 中是否有 Item 信息。

    • 正常情况下,会含有 item 信息,示例如下:

      UnionResourceResult{success=true, message=成功, info=[UnionResourceInfo{bizType=NEBULA, success=true, rollback=false, item=[UnionResourceItem{resId=2021011520210115, resVersion=1.0.5.1, fileMD5=9a31d39d20301b74c93317e75f36dd58, fileUrl=https://mcube-prod.oss-cn-hangzhou.aliyuncs.com/ONEX4CFD5B3081617-default/2021011520210115/1.0.5.1_all/nebula/2021011520210115_1.0.5.1.amr, downloadType=CDN, storeType=MEM, resStatus=1, resExtraData=[UnionExtraData{key=app_type, value=1}, UnionExtraData{key=resType, value=4}, UnionExtraData{key=autoinstall, value=1}, UnionExtraData{key=fallbackbaseurl, value=https://mcube-prod.oss-cn-hangzhou.aliyuncs.com/ONEX4CFD5B3081617-default/2021011520210115/1.0.5.1_all/nebula/fallback/}, UnionExtraData{key=scene, value=DEBUG}...,
    • 若未包含 item 信息,则为异常,示例如下:

      [URGENT_DISP_12] mpaas_url = https://cn-hangzhou-component-gw.cloud.alipay.com/mgw.htm
      DynamicRelease: [NetworkThread#1] DynamicReleaseLauncher rpc time: 1611736340256
      DynamicRelease: [URGENT_DISP_12] rpc result: UnionResourceResult{success=true, message=成功, info=[UnionResourceInfo{bizType=NEBULA, success=true, rollback=false, quickRollback=0}]}
  2. 检查接入真机预览和调试功能。 按照 Android 小程序接入真机预览与调试中的步骤检查接入真机预览和调试是否正确。

  3. 检查客户端版本范围。 版本号对应 Android 项目 versionName 值。只有当最低版本号 < 当前 App 版本号 < 最高版本号时,才能正常的拉取小程序。若不在这个范围,App 启动小程序时就会拉取失败,报 “应用更新错误”。 所以 推荐 在最低版本输入 0.0.0.0,最高版本不填写(表示无限大)。

    说明

    由于在小程序 IDE 上传、预览、真机调试会自动将小程序上传至控制台,无需用户在控制台修改配置信息,所以在创建小程序时,不推荐 从小程序发布中添加小程序包,防止出现主路径不一致。如要修改小程序,可以在小程序 IDE 中修改。

  4. 检查主入口路径。 查看 mPaaS 控制台中填写的小程序主入口路径是否与小程序 IDE 中的主入口路径一致。 mPaaS控制台默认主路径格式为:/index.html#xxx/xxx/xxx/xxx,其中 # 后方的 xxx/xxx/xxx/xxx 是小程序的 app.json 中的 pages 中的第一个值。

如果依然不能解决问题,请准备好相关问题的复现 Demo 工程,加入钉钉答疑群 41708565 咨询。

  • 本页导读 (0)
文档反馈