为有牺牲多壮志,敢教日月换新天。

HarmonyOS:应用/元服务上架(2)

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤博客园地址:为敢技术(https://www.cnblogs.com/strengthen/ 
➤GitHub地址:https://github.com/strengthen
➤原文地址:https://www.cnblogs.com/strengthen/p/18511438
➤如果链接不是为敢技术的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

  

概述

当您开发、调试完HarmonyOS应用/元服务,就可以前往AppGallery Connect申请上架,华为审核通过后,用户即可在华为应用市场获取您的HarmonyOS应用/元服务。

HarmonyOS会通过数字证书与Profile文件等签名信息来保证应用的完整性,需要上架的HarmonyOS应用/元服务都必须通过签名校验,所以上架前,您需要先完成签名操作。

创建项目

  1. 登录AppGallery Connect,点击“我的项目”。
  2. 在项目页面中点击“添加项目”。
  3. 在“创建项目”页面中输入项目名称后 ,点击“创建并继续”。

  4. 项目创建后会进入“开通分析服务”页面。此时可以开通分析服务,以便通过报表查看相关指标数据,也可以创建完项目后开通。

创建HarmonyOS应用/元服务

  1. 在项目列表中点击需要操作的项目。
  2. 点击“添加应用”创建应用/元服务。
    • 项目中没有应用,在“项目设置”页面点击“添加应用”。

    • 项目中有应用,展开顶部应用列表框,点击“添加应用”。

  3. 填写相关信息,点击“确认”。
    • 选择平台:选择“APP(HarmonyOS)”。
    • 应用包名:需要和DevEco Studio创建工程时填写的“bundleName”值保持一致。
    • “是否元服务”:HarmonyOS应用选择“否”,元服务选择“是”。

编译打包HarmonyOS应用/元服务

完整编译流程如下图所示。

生成密钥和证书请求文件

  1. 打开DevEco Studio,菜单选择“Build > Generate Key and CSR”。
  2. Key Store File可以点击“Choose Existing”选择已有的密钥库文件(存储有密钥的.p12文件),跳转至步骤4继续配置;如果没有密钥库文件,点击“New”,跳转至步骤3进行创建。

  3. 在“Create Key Store”界面,填写密钥库信息后,点击“OK”。
    • Key Store File:设置密钥库文件存储路径,并填写p12文件名。
    • Password:设置密钥库密码,必须由大写字母、小写字母、数字和特殊符号中的两种以上字符的组合,长度至少为8位。请记住该密码,后续签名配置需要使用。
    • Confirm Password:再次输入密钥库密码。
  4. 在“Generate Key and CSR”界面继续填写密钥信息后,点击“Next”。
    • Alias:密钥的别名信息,用于标识密钥名称。请记住该别名,后续签名配置需要使用。
    • Password:密钥对应的密码,与密钥库密码保持一致,无需手动输入。
    • Validity:证书有效期,建议设置为25年及以上,覆盖元服务的完整生命周期。
    • Certificate:输入证书基本信息,如组织、城市或地区、国家码等。

  5. 在“Generate Key and CSR”界面设置CSR文件存储路径和CSR文件名,点击“Finish”。

    CSR文件创建成功后,将在存储路径下获取生成密钥库文件(.p12)和证书请求文件(.csr)。

申请发布证书

  1. 登录AppGallery Connect,选择“用户与访问”。
  2. 左侧导航栏选择“证书管理”,进入“证书管理”页面,点击“新增证书”。

  3. 在弹出“新增证书”界面填写相关信息后,点击“提交”。

    参数

    说明

    证书名称

    不超过100个字符。

    证书类型

    选择“发布证书”。

    上传证书请求文件(CSR)

    上传生成密钥和证书请求文件时获取的.csr文件。

  4. 证书申请成功后,“证书管理”页面展示生成的证书内容。
    • 点击“下载”将生成的证书保存至本地。
    • 每个帐号最多申请1个发布证书,如果证书已过期或者无需使用,点击“废除”即可删除证书。

申请发布Profile

  1. 登录AppGallery Connect,选择“我的项目”。
  2. 找到对应项目,点击项目卡片中需要发布的元服务。
  3. 导航选择“HarmonyOS应用 > HAP Provision Profile管理”,进入“管理HAP Provision Profile”页面,点击“添加”。

  4. 在“HarmonyAppProvision信息”界面填写相关信息,点击“提交”。
    说明

    如果您发布的应用支持API 9及以上版本,且需要使用ACL申请的权限,请提供APP ID发送到agconnect@huawei.com。待运营审核通过后,才可以看到“受限ACL权限”选项进行配置。

    参数

    说明

    名称

    不超过100个字符。

    类型

    选择“发布”。

    选择证书

    选择申请的发布证书。

    申请权限

    • 如应用需要申请受限权限,选择“受限权限(HarmonyOS API9以下)”,该选项支持申请如下受限权限:
      • ohos.permission.READ_CONTACTS(允许应用读取联系人数据)
      • ohos.permission.WRITE_CONTACTS(允许应用添加、移除和更改联系人数据)
    • 如应用需要申请ACL权限,请选择“受限ACL权限(HarmonyOS API9及以上)”,该选项支持申请允许ACL申请的权限
    说明

    请确保您此处申请的权限与软件包内配置的权限一致。

  5. 申请成功,即可在“管理HAP Provision Profile”页面查看Profile信息。点击“下载”,将文件下载到本地。

配置签名信息

  1. 打开DevEco Studio,菜单选择“File > Project Structure”,进入“Project Structure”界面。
  2. 导航选择“Project”,点击“Signing Configs”页签,填写相关信息后,点击“OK”。
    • Store File:密钥库文件,选择生成密钥和证书请求文件时生成的.p12文件。
    • Store Password:密钥库密码,需要与生成密钥和证书请求文件时设置的密钥库密码保持一致。
    • Key alias:密钥的别名信息,需要与生成密钥和证书请求文件时设置的别名保持一致。
    • Key password:密钥的密码,需要与生成密钥和证书请求文件时设置的密码保持一致。
    • Sign alg:固定设置为“SHA256withECDSA”。
    • Profile file:选择申请发布Profile时下载的.p7b文件。
    • Certpath file:选择申请发布Profile时下载的.cer文件。

编译打包

  1. 打开DevEco Studio,菜单选择“Build > Build Hap(s)/APP(s) > Build APP(s)”。
  2. 等待编译构建签名的HarmonyOS应用/元服务,编译完成后,可在工程目录build > outputs > default目录下获取用于上架的软件包。

上架HarmonyOS应用/元服务

  1. 登录AppGallery Connect,选择“我的应用”。
  2. 在应用列表首页中点击“HarmonyOS”页签。
  3. 点击待发布的应用/元服务,在左侧导航栏选择“应用信息”菜单。
  4. 填写应用的基本信息,如语言,应用名称,应用介绍等,上传应用图标,所有配置完成后点击“保存”。

    详细配置指导请参见官网文档:HarmonyOS应用 元服务

  5. 填写版本信息,如发布国家或地区、上传软件包、提交资质材料等,所有配置完成后点击右上角“提交审核”。

    详细配置指导请参见官网文档:HarmonyOS应用 元服务

常见问题总结

以下罗列了出错频率较高的问题,更多异常处理请参见软件包解析错误说明

上传软件包,提示“Profile文件非法”,如何处理?

出现此错误,原因可能有以下两种。

  • 原因一:软件包使用的Profile已被删除,如下图,应用下无发布Profile。您需要申请发布Profile,然后重新打包上传。 

  • 原因二:软件包中使用的发布Profile文件并非当前待发布应用的,常见的错误是下载、使用了其他应用的Profile文件。

    例如:下载了HarmonyA应用的Profile文件,并将此Profile文件打入HarmonyB应用包中。

    那么在发布HarmonyB应用时,上传软件包就会出现此错误。

上传软件包,提示“使用的Profile和证书不匹配”,如何处理?

出现此错误,一般是由于软件包中使用的发布证书与发布Profile文件中使用的发布证书不一致。请排查确认DevEco Studio打包时配置的发布证书,是否为配置的Profile文件中使用的发布证书。

上传软件包,提示“非法软件包”,如何处理?

出现此错误,可能是软件包未签名,请检查编译环境,确认是否使用了签名文件。或者是否有进行拆包再手动打包,导致未正确签名。建议使用DevEco Studio中配置签名后重新编译打包。

上传软件包时,提示“软件包中使用证书已被删除”,如何处理?

出现此错误,一般是软件包中使用的证书已经被删除。请访问AppGallery Connect申请Profile的页面,检查打包使用Profile是否还存在。如果已删除,需要重新申请新的发布证书新的发布Profile,并重新编译打包新的软件包。

 

posted @ 2024-10-28 19:30  为敢技术  阅读(18)  评论(0编辑  收藏  举报