0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

OpenHarmony應用簽名方法的步驟

OpenAtom OpenHarmony ? 來源:OpenAtom OpenHarmony ? 作者:OpenAtom OpenHarmony ? 2022-10-13 09:41 ? 次閱讀

背景

OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)應用如果需要對外發(fā)布就必須要通過應用簽名,DevEco Studio已提供自動簽名功能加速應用開發(fā),但自動簽名僅限于debug開發(fā),如需對外發(fā)布則必須完成release簽名。在OpenHarmony中有AGC應用商店可以幫助開發(fā)者完成release簽名,本文將介紹OpenHarmony應用簽名方法的步驟,將使用OpenHarmony官方提供的簽名工具對HAP進行簽名。

使用DevEco Studio完成HAP自動簽名

打開DevEco Studio工具,點擊右上角Project Structure進入工程配置頁面

7fef6fae-4a2f-11ed-a3b6-dac502259ad0.png

點擊Project -> Signing Configs,勾選Automatically generate signing,點擊OK

8004ffea-4a2f-11ed-a3b6-dac502259ad0.png

點擊Build -> Rebuild Project 或 Build HAP都可以編譯構(gòu)建HAP包

80314442-4a2f-11ed-a3b6-dac502259ad0.png

編輯構(gòu)建完成后我們可以得到未簽名的HAP包

803dde8c-4a2f-11ed-a3b6-dac502259ad0.png

這個包可以用于Debug調(diào)試,但不能用于Release正式發(fā)布

IDE對HAP包簽名的密碼限制

從理論上講,我們也可以通過DevEco Studio進行HAP包的發(fā)布簽名,但是官方提供的OpenHarmony.p12文件密碼為123456

而IDE不支持使用123456這樣的簡單的密碼,它達不到密碼安全級別

80485146-4a2f-11ed-a3b6-dac502259ad0.png

8065703c-4a2f-11ed-a3b6-dac502259ad0.png

因此,使用官方加密文件完成簽名暫時行不通

我們改變思路,使用命令行方式完成簽名,這樣可以繞過IDE的限制

使用官方開源簽名工具完成簽名

查閱官方資料發(fā)現(xiàn),官方已經(jīng)提供了命令行簽名工具

https://gitee.com/openharmony/developtools_hapsigner

我們通過修改配置文件、執(zhí)行腳本,即可完成HAP簽名具體步驟如下:

1 安裝工具依賴環(huán)境

安裝python3.10(下載鏈接:https://www.python.org/downloads/),通過命令行驗證安裝是否成功

8080bf36-4a2f-11ed-a3b6-dac502259ad0.png

安裝jdk,配置好環(huán)境變量,通過命令行驗證安裝是否成功

80996644-4a2f-11ed-a3b6-dac502259ad0.png

2 將簽名工具代碼拉取到本地保存,修改配置文件

git clone https://gitee.com/openharmony/developtools_HAPsigner.git

修改developtools_HAPsignerautosignsignHAP.config文件配置

# config.signtool改為HAP-sign-tool.jar的絕對路徑,可以在dist目錄中找到

config.signtool=E:/openharmony/developtools_HAPsigner/dist/HAP-sign-tool.jar

# common.keystoreFile改為OpenHarmony.p12的絕對路徑,可以在dist目錄中找到

common.keystoreFile=E:/openharmony/developtools_HAPsigner/dist/OpenHarmony.p12

# app.keypair.keyAlias改為OpenHarmony Application Release

app.keypair.keyAlias=OpenHarmony Application Release

# cert.app.outFile改為OpenHarmonyApplication.pem的絕對路徑,可以在dist目錄中找到

cert.app.outFile=E:/openharmony/developtools_HAPsigner/dist/OpenHarmonyApplication.pem

# sign.profile.outFile改為官方提供的p7b絕對路徑,比如launcher代碼中提供了launcher.p7b加密文件

sign.profile.outFile=E:/openharmony/signfiles/launcher/launcher.p7b

# sign.app.inFile為未簽名HAP路徑

sign.app.inFile=E:/openharmony/applications_launcher/product/phone/build/default/outputs/default/phone-launcher-default-unsigned.HAP

# sign.app.outFile為簽名后的HAP保存路徑

sign.app.outFile=E:/openharmony/applications_launcher/product/phone/build/default/outputs/default/phone-launcher-signed.HAP

3 完成配置文件修改后,執(zhí)行簽名腳本

# 進入簽名工具autosign目錄

cd E:openharmonydeveloptools_HAPsignerautosign

# 執(zhí)行python腳本

python .autosign.py signHAP

簽名成功后顯示Success

80c3c538-4a2f-11ed-a3b6-dac502259ad0.png

到指定目錄下可以找到簽名后的HAP

80d051f4-4a2f-11ed-a3b6-dac502259ad0.png

總結(jié)

DevEco Studio開發(fā)工具為開發(fā)人員提供了非常友好的HAP自動簽名功能及非常便捷的Debug包。由于IDE的安全密碼要求,對于Release包的發(fā)布我們暫時需要手動簽名,尤其是系統(tǒng)級的應用。我們可以利用官方提供的簽名工具較為容易地完成release包簽名,后續(xù)可以自行開發(fā)GUI工具進一步提升簽名效率。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • OpenHarmony
    +關注

    關注

    25

    文章

    3722

    瀏覽量

    16313
  • DevEco Studio
    +關注

    關注

    0

    文章

    21

    瀏覽量

    1088

原文標題:OpenHarmony應用HAP包簽名

文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    OpenHarmony原子化服務開發(fā)快速入門體驗(下)

    五、配置openharmony應用簽名信息 采用自動配簽名方法,將設備使用USB數(shù)據(jù)線連接到電腦后,依次點擊File-ProjectStructure-Project-Signing
    的頭像 發(fā)表于 06-22 10:11 ?2428次閱讀
    <b class='flag-5'>OpenHarmony</b>原子化服務開發(fā)快速入門體驗(下)

    OpenHarmony2.0 上安裝自己的系統(tǒng)應用

    廢話不多說,先上效果圖:使用該方法安裝的hap為系統(tǒng)hap,不可卸載。文檔寫的使用hdc安裝hap暫未走通。請參考官方文檔。有打包、簽名(建議參考一下官方文檔的簽名,和HarmonyOS簽名
    發(fā)表于 08-09 14:35

    HarmonyOS與OpenHarmony應用開發(fā)差異

    工程的方式來創(chuàng)建一個新工程。調(diào)試簽名配置:OpenHarmony應用運行在真機設備上,需要對應用進行簽名。在真機設備上運行應用:需要使用hdc工具將OpenHarmony的hap包推送
    發(fā)表于 10-22 10:35

    基于OpenHarmony應用開發(fā)的簽名配置

    開發(fā)OpenHarmony應用的第一步就是配置環(huán)境,如果你需要使用開發(fā)板(真機)進行調(diào)試,那就免不了配置簽名信息,本文詳細介紹了基于OpenHarmony應用開發(fā)的簽名配置。
    發(fā)表于 03-11 15:32

    OpenHarmony應用的簽名配置的流程解析

      使用真機設備運行和調(diào)試OpenHarmony應用前,需要對應用進行簽名才能正常運行。該指導用于OpenHarmony應用的簽名配置。除此章節(jié)以外,DevEco Studio的其余操
    發(fā)表于 03-14 16:40

    OpenHarmony hap包安裝失敗的原因及其解決方法解析

    OpenHarmony hap包安裝:error: failed to install bundle. error: install update incompatible.簽名認證
    發(fā)表于 03-15 14:15

    OpenHarmony設置自動化簽名報錯怎么解決?

    選擇這個自動化簽名又又出錯了,按照文檔的內(nèi)容,使用keytool和java又手動生成簽名,沒有找到這個工具,下載了JDK,找到了工具,在生成文件的時候報錯了。自動簽名怎么解決?
    發(fā)表于 05-07 10:52

    燒錄OpenHarmony 3.2(嘗鮮版)步驟

    工具是配套的燒錄OpenHarmony版本相應SDK也從每日構(gòu)件中下載:http://ci.openharmony.cn/dailys/dailybuilds燒錄升級3.2版本步驟:燒錄3.2版本
    發(fā)表于 05-22 12:14

    OpenHarmony原子化服務開發(fā)快速入門體驗(下)

    五、配置openharmony應用簽名信息采用自動配簽名方法,將設備使用USB數(shù)據(jù)線連接到電腦后,依次點擊File->ProjectStructure->
    發(fā)表于 06-22 09:56

    OpenHarmony應用Hap包簽名

    。在HarmonyOS中有AGC應用商店可以幫助開發(fā)者完成release簽名,但是OH就沒有這么方便了,本文將介紹OH應用簽名方法步驟,將使用OH官方提供的
    發(fā)表于 09-20 09:18

    OpenHarmony應用HAP包簽名

    OpenHarmony應用簽名方法步驟,將使用OpenHarmony官方提供的簽名工具對HAP
    發(fā)表于 10-13 17:11

    簽名簽名”之實現(xiàn)技術研究

    介紹“簽名簽名”,即筆跡數(shù)字簽名的概念,提出直接和需仲裁的“簽名簽名”之2種結(jié)構(gòu)模式。針對簽名
    發(fā)表于 04-20 09:30 ?15次下載

    OpenHarmony Dev-Board-SIG專場:HDF驅(qū)動移植步驟

    OpenHarmony Dev-Board-SIG專場:HDF驅(qū)動移植步驟
    的頭像 發(fā)表于 12-28 14:46 ?1920次閱讀
    <b class='flag-5'>OpenHarmony</b> Dev-Board-SIG專場:HDF驅(qū)動移植<b class='flag-5'>步驟</b>

    技術專家分享:OpenHarmony應用HAP包簽名

    可以幫助開發(fā)者完成release簽名,本文將介紹OpenHarmony應用簽名方法步驟,將使用Open
    的頭像 發(fā)表于 10-18 09:35 ?2457次閱讀

    OpenHarmony開發(fā)實例:【配置應用簽名信息】

    使用真機設備運行和調(diào)試OpenHarmony應用前,需要對應用進行簽名才能正常運行。
    的頭像 發(fā)表于 04-22 16:52 ?467次閱讀
    <b class='flag-5'>OpenHarmony</b>開發(fā)實例:【配置應用<b class='flag-5'>簽名</b>信息】