在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

鴻蒙OS開發(fā)指導(dǎo):【應(yīng)用包簽名工具】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-17 11:13 ? 次閱讀

編譯構(gòu)建

  1. 該工具基于Maven3編譯構(gòu)建,請確認環(huán)境已安裝配置Maven3環(huán)境,并且版本正確
    mvn -version
    
  2. 下載代碼,命令行打開文件目錄至developtools_hapsigner/hapsigntool,執(zhí)行命令進行編譯打包
    mvn package
    
  3. 編譯后得到二進制文件,目錄為: ./hap_sign_tool/target

開發(fā)指導(dǎo)

鴻蒙開發(fā)指導(dǎo)書:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

場景介紹

OpenHarmony系統(tǒng)內(nèi)置密鑰庫文件,文件名稱為OpenHarmony.p12,內(nèi)含根CA證書、中間CA證書、最終實體證書等信息,工具基于該密鑰庫文件對OpenHarmony應(yīng)用進行簽名。

按照有無應(yīng)用簽名證書可分為以下兩種場景:

  1. 無應(yīng)用簽名證書場景: 開發(fā)者使用該工具對應(yīng)用包簽名時,需按照簽名步驟從第一步生成應(yīng)用簽名證書密鑰對依次完成應(yīng)用簽名證書生成、profile文件簽名、應(yīng)用簽名流程。
  2. 有應(yīng)用簽名證書場景: 開發(fā)者可直接從簽名步驟第三步對profile文件進行簽名開始開發(fā),使用應(yīng)用簽名證書和包含對應(yīng)密鑰的本地密鑰庫文件對應(yīng)用進行簽名。

搜狗高速瀏覽器截圖20240326151547.png

命令說明

  1. 輸出命令幫助信息。
    -help     # 輸出命令幫助信息(不輸入參數(shù)默認輸出命令幫助信息)
    
  2. 輸出版本信息。
    -version  # 輸出版本信息
    
  3. 生成密鑰對。
    generate-keypair : 生成密鑰對
        ├── -keyAlias          # 密鑰別名,必填項
        ├── -keyPwd            # 密鑰口令,可選項
        ├── -keyAlg            # 密鑰算法,必填項,包括RSA/ECC
        ├── -keySize           # 密鑰長度,必填項,RSA算法的長度為2048/3072/4096,ECC算法的長度NIST-P-256/NIST-P-384
        ├── -keystoreFile      # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd       # 密鑰庫口令,可選項
    
  4. 生成證書簽名請求。
    generate-csr : 生成證書簽名請求
        ├── -keyAlias          # 密鑰別名,必填項
        ├── -keyPwd            # 密鑰口令,可選項
        ├── -subject           # 證書主題,必填項
        ├── -signAlg           # 簽名算法,必填項,包括SHA256withRSA / SHA384withRSA / SHA256withECDSA / SHA384withECDSA
        ├── -keystoreFile      # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd       # 密鑰庫口令,可選項
        ├── -outFile           # 輸出文件,可選項,如果不填,則直接輸出到控制臺
    
  5. 生成根CA/中間CA證書。
    generate-ca : 生成根CA/中間CA證書,如果密鑰不存在,一起生成密鑰
        ├── -keyAlias                        # 密鑰別名,必填項
        ├── -keyPwd                          # 密鑰口令,可選項
        ├── -keyAlg                          # 密鑰算法,必填項,包括RSA/ECC
        ├── -keySize                         # 密鑰長度,必填項,RSA算法的長度為2048/3072/4096,ECC算法的長度NIST-P-256/NIST-P-384
        ├── -issuer                          # 頒發(fā)者的主題,可選項,如果不填,表示根CA
        ├── -issuerKeyAlias                  # 頒發(fā)者的密鑰別名,可選項,如果不填,表示根CA
        ├── -issuerKeyPwd                    # 頒發(fā)者的密鑰口令,可選項
        ├── -subject                         # 證書主題,必填項
        ├── -validity                        # 證書有效期,可選項,默認為3650天
        ├── -signAlg                         # 簽名算法,必填項,包括SHA256withRSA / SHA384withRSA / SHA256withECDSA / SHA384withECDSA
        ├── -basicConstraintsPathLen         # 路徑長度,可選項,默認為0
        ├── -keystoreFile                    # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd                     # 密鑰庫口令,可選項
        ├── -issuerKeystoreFile              # 簽發(fā)者密鑰庫文件,可選項,JKS或P12格式
        ├── -issuerKeystorePwd               # 簽發(fā)者密鑰庫口令,可選項
        ├── -outFile                         # 輸出文件,可選項,如果不填,則直接輸出到控制臺
    
  6. 生成應(yīng)用調(diào)試/發(fā)布證書。
    generate-app-cert : 生成應(yīng)用調(diào)試/發(fā)布證書
        ├── -keyAlias                        # 密鑰別名,必填項
        ├── -keyPwd                          # 密鑰口令,可選項
        ├── -issuer                          # 頒發(fā)者的主題,必填項
        ├── -issuerKeyAlias                  # 頒發(fā)者的密鑰別名,必填項
        ├── -issuerKeyPwd                    # 頒發(fā)者的密鑰口令,可選項
        ├── -subject                         # 證書主題,必填項
        ├── -validity                        # 證書有效期,可選項,默認為3650天
        ├── -signAlg                         # 簽名算法,必填項,包括SHA256withECDSA / SHA384withECDSA;
        ├── -issuerKeystoreFile              # 簽發(fā)者密鑰庫文件,可選項,JKS或P12格式
        ├── -issuerKeystorePwd               # 簽發(fā)者密鑰庫口令,可選項
        ├── -keystoreFile                    # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd                     # 密鑰庫口令,可選項
        ├── -outForm                         # 輸出證書文件的格式,包括 cert / certChain,可選項,默認為certChain
        ├── -rootCaCertFile                  #  outForm為certChain時必填,根CA證書文件
        ├── -subCaCertFile                   #  outForm為certChain時必填,中間CA證書文件
        ├── -outFile                         #  輸出證書文件(證書或證書鏈),可選項,如果不填,則直接輸出到控制臺
    
  7. 生成profile調(diào)試/發(fā)布證書。
    generate-profile-cert : 生成profile調(diào)試/發(fā)布證書
        ├── -keyAlias                        # 密鑰別名,必填項
        ├── -keyPwd                          # 密鑰口令,可選項
        ├── -issuer                          # 頒發(fā)者的主題,必填項
        ├── -issuerKeyAlias                  # 頒發(fā)者的密鑰別名,必填項
        ├── -issuerKeyPwd                    # 頒發(fā)者的密鑰口令,可選項
        ├── -subject                         # 證書主題,必填項
        ├── -validity                        # 證書有效期,可選項,默認為3650天
        ├── -signAlg                         # 簽名算法,必填項,包括SHA256withECDSA / SHA384withECDSA;
        ├── -issuerKeystoreFile              # 簽發(fā)者密鑰庫文件,可選項,JKS或P12格式
        ├── -issuerKeystorePwd               # 簽發(fā)者密鑰庫口令,可選項
        ├── -keystoreFile                    # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd                     # 密鑰庫口令,可選項
        ├── -outForm                         # 輸出證書文件的格式,包括 cert / certChain,可選項,默認為certChain
        ├── -rootCaCertFile                  #  outForm為certChain時必填,根CA證書文件
        ├── -subCaCertFile                   #  outForm為certChain時必填,中間CA證書文件
        ├── -outFile                         #  輸出證書文件(證書或證書鏈),可選項,如果不填,則直接輸出到控制臺
    
  8. 通用證書生成,可以生成自定義證書。
    generate-cert : 通用證書生成,可以生成自定義證書
        ├── -keyAlias                          # 密鑰別名,必填項
        ├── -keyPwd                            # 密鑰口令,可選項
        ├── -issuer                            # 頒發(fā)者的主題,必填項
        ├── -issuerKeyAlias                    # 頒發(fā)者的密鑰別名,必填項
        ├── -issuerKeyPwd                      # 頒發(fā)者的密鑰口令,可選項
        ├── -subject                           # 證書主題,必填項
        ├── -validity                          # 證書有效期,可選項,默認為1095天
        ├── -keyUsage                          # 密鑰用法,必選項,包括digitalSignature, nonRepudiation, keyEncipherment,
                                                dataEncipherment, keyAgreement, certificateSignature, crlSignature,
                                                encipherOnly和decipherOnly,如果證書包括多個密鑰用法,用逗號分隔
        ├── -keyUsageCritical                  # keyUsage是否為關(guān)鍵項,可選項,默認為是
        ├── -extKeyUsage                       # 擴展密鑰用法,可選項,包括clientAuthentication,serverAuthentication,
                                                codeSignature,emailProtection,smartCardLogin,timestamp,ocspSignature
        ├── -extKeyUsageCritical               # extKeyUsage是否為關(guān)鍵項,可選項,默認為否
        ├── -signAlg                           # 簽名算法,必填項,包括SHA256withRSA/SHA384withRSA/SHA256withECDSA/SHA384withECDSA 
        ├── -basicConstraints                  # 是否包含basicConstraints,可選項,默認為否
        ├── -basicConstraintsCritical          # basicConstraints是否包含為關(guān)鍵項,可選項,默認為否
        ├── -basicConstraintsCa                # 是否為CA,可選項,默認為否
        ├── -basicConstraintsPathLen           # 路徑長度,可選項,默認為0
        ├── -issuerKeystoreFile                # 簽發(fā)者密鑰庫文件,可選項,JKS或P12格式
        ├── -issuerKeystorePwd                 # 簽發(fā)者密鑰庫口令,可選項
        ├── -keystoreFile                      # 密鑰庫文件,必填項,JKS或P12格式
        ├── -keystorePwd                       # 密鑰庫口令,可選項
        ├── -outFile                           # 輸出證書文件,可選項,如果不填,則直接輸出到控制臺
    
  9. profile文件簽名。
    sign-profile : profile文件簽名
        ├── -mode            # 簽名模式,必填項,包括localSign,remoteSign
        ├── -keyAlias        # 密鑰別名,必填項
        ├── -keyPwd          # 密鑰口令,可選項
        ├── -profileCertFile # Profile簽名證書(證書鏈,順序為最終實體證書-中間CA證書-根證書),必填項
        ├── -inFile          # 輸入原始的模板Profile文件,文件為json格式,所在目錄為developtools_hapsigner/autosign/UnsgnedReleasedProfileTemplate.json,必填項
        ├── -signAlg         # 簽名算法,必填項,包括SHA256withECDSA / SHA384withECDSA
        ├── -keystoreFile    # 密鑰庫文件,localSign模式時為必填項,JKS或P12格式
        ├── -keystorePwd     # 密鑰庫口令,可選項
        ├── -outFile         # 輸出簽名后的profile文件,p7b格式,必填項
    
  10. profile文件驗簽。
verify-profile : profile文件驗簽
    ├── -inFile       # 已簽名的profile文件,p7b格式,必填項
    ├── -outFil       # 驗證結(jié)果文件(包含驗證結(jié)果和profile內(nèi)容),json格式,可選項;如果不填,則直接輸出到控制臺
  1. 應(yīng)用包和調(diào)試工具簽名。
sign-app : 應(yīng)用包和二進制工具簽名
    ├── -mode          # 簽名模式,必填項,包括localSign,remoteSign,remoteResign
    ├── -keyAlias      # 密鑰別名,必填項
    ├── -keyPwd        # 密鑰口令,可選項
    ├── -appCertFile   # 應(yīng)用簽名證書文件(證書鏈,順序為實體證書-中間CA證書-根證書),必填項
    ├── -profileFile   # 簽名后的Provision Profile文件名,profileSigned為1時為p7b格式,profileSigned為0時為json格式,應(yīng)用包簽名必填項,二進制工具簽名選填
    ├── -profileSigned # 指示profile文件是否帶有簽名,1表示有簽名,0表示沒有簽名,默認為1??蛇x項
    ├── -inForm        # 輸入的原始文件的格式,枚舉值:zip、elf或bin;zip應(yīng)用包對應(yīng)zip,二進制工具對應(yīng)elf,bin應(yīng)用包為bin,默認zip;可選項
    ├── -inFile        # 輸入的原始文件,應(yīng)用包、elf或bin文件,必填項
    ├── -signAlg       # 簽名算法,必填項,包括SHA256withECDSA / SHA384withECDSA
    ├── -keystoreFile  # 密鑰庫文件,localSign模式時為必填項,JKS或P12格式
    ├── -keystorePwd   # 密鑰庫口令,可選項
    ├── -outFile       # 輸出簽名后的包文件,必填項
    ├── -signCode      # 是否啟用代碼簽名,1表示開啟代碼簽名,0表示關(guān)閉代碼簽名。可選項。默認對hap、hsp、hqf、elf開啟代碼簽名,通過參數(shù)配置為0關(guān)閉。
  1. 應(yīng)用包和調(diào)試工具文件驗簽。
verify-app : 應(yīng)用包和二進制工具文件驗簽
   ├── -inFile          # 已簽名的文件,應(yīng)用包、elf或bin文件,必填項
   ├── -outCertChain    # 簽名的證書鏈文件,必填項
   ├── -outProfile      # 應(yīng)用包中的profile文件,必填項
   ├── -inForm          # 輸入的原始文件的格式,枚舉值:zip、elf或bin;zip應(yīng)用包對應(yīng)zip,二進制工具對應(yīng)elf,bin應(yīng)用包為bin,默認zip;可選項

簽名步驟

對應(yīng)用包簽名的完整步驟為:

  • 生成應(yīng)用簽名證書密鑰對
  • 生成應(yīng)用簽名證書
  • 對profile文件進行簽名
  • 對應(yīng)用包進行簽名

注意事項:

  1. 步驟一中的密鑰對算法推薦使用ECC,出于安全性考慮,應(yīng)用簽名暫不使用RSA算法。
  2. 建議將待簽名應(yīng)用包、profile文件、密鑰庫文件OpenHarmony.p12、根CA證書、中間CA證書、簽名工具放在同一個目錄下,方便操作。
  1. 生成應(yīng)用簽名證書密鑰對
    調(diào)用密鑰對生成接口,生成簽名密鑰并保存到密鑰庫。
    命令實例:

    java -jar hap-sign-tool.jar generate-keypair -keyAlias "oh-app1-key-v1" -keyAlg "ECC"  -keySize "NIST-P-256" -keystoreFile "OpenHarmony.p12" -keyPwd "123456" -keystorePwd "123456"
    

    說明:

    請記錄下keyAlias、keyStorePwdkeyPwd的值,在后續(xù)生成應(yīng)用簽名證書和對應(yīng)用包進行簽名操作會使用到。

    該命令的參數(shù)說明:

    generate-keypair : 生成應(yīng)用簽名證書密鑰對
        ├── -keyAlias         #用于生成應(yīng)用簽名證書的密鑰別名,存于OpenHarmony.p12密鑰庫文件中,該參數(shù)必填
        ├── -keyAlg           #密鑰算法,推薦使用ECC,該參數(shù)必填
        ├── -keySize          #密鑰長度,ECC算法的長度NIST-P-256/NIST-P-384,該參數(shù)必填
        ├── -keyStoreFile     #密鑰庫文件,推薦使用提供的OpenHarmony.p12密鑰庫文件,該參數(shù)必填
        ├── -keyStorePwd      #密鑰庫口令,OpenHarmony.p12口令默認為“123456”,必填項
        ├── -keyPwd           #密鑰口令,可選項,該參數(shù)不填默認生成的密鑰對無口令
    
  2. 生成應(yīng)用簽名證書
    調(diào)用應(yīng)用簽名證書生成接口,使用本地中間CA證書簽發(fā)應(yīng)用簽名證書。
    命令實例:

    java -jar hap-sign-tool.jar generate-app-cert -keyAlias "oh-app1-key-v1" -signAlg "SHA256withECDSA"  -issuer "C=CN,O=OpenHarmony,OU=OpenHarmony Team,CN= OpenHarmony Application CA" -issuerKeyAlias "openharmony application ca" -subject "C=CN,O=OpenHarmony,OU=OpenHarmony Team,CN=OpenHarmony Application Release" -keystoreFile "OpenHarmony.p12" -subCaCertFile "subCA.cer" -rootCaCertFile "rootCA.cer" -outForm "certChain" -outFile "app1.pem" -keyPwd "123456" -keystorePwd "123456" -issuerKeyPwd "123456" -validity "365"
    

    該命令的參數(shù)說明:

    generate-app-cert:生成應(yīng)用簽名證書
        ├── -keyAlias         # 用于生成應(yīng)用簽名證書的密鑰別名,請與第一步生成密鑰對的密鑰別名-keyAlias保持一致
        ├── -signAlg          # 簽名算法,必填項,包括 SHA256withECDSA / SHA384withECDSA
        ├── -issuer           # 頒發(fā)者主題,填寫已提供的中間CA證書主題,該參數(shù)必填且不能修改
        ├── -issuerKeyAlias   # 頒發(fā)者密鑰別名,填寫中間CA證書密鑰別名,該參數(shù)必填且不能修改
        ├── -subject          # 證書主題,請參照命令實例中內(nèi)容保證順序不變,該參數(shù)必填
        ├── -issuerKeyPwd     # 頒發(fā)者密鑰口令,填寫中間CA證書密鑰口令,該參數(shù)必填,指定“123456”,不可修改
        ├── -keystoreFile     # 密鑰庫文件,指定使用提供的OpenHarmony.p12密鑰庫文件,該參數(shù)必填且不可修改
        ├── -rootCaCertFile   # 根CA證書文件,指定為已提供的根CA證書,該參數(shù)必填且不可修改
        ├── -subCaCertFile    # 中間CA證書文件,指定為已提供的中間CA證書,該參數(shù)必填且不可修改
        ├── -outForm          # 輸出證書文件格式,推薦使用certChain
        ├── -outFile          # 可選項,建議填寫,不填則默認輸出到控制臺
        ├── -keyPwd           # 密鑰口令,可選項,為第一步生成的密鑰對口令
        ├── -keystorePwd      # 密鑰庫口令,默認為“123456”
        ├── -validity         # 證書有效期,可選項,默認為3650天
    
  3. 對profile文件進行簽名
    調(diào)用profile文件簽名接口,使用Profile簽名密鑰對profile文件進行簽名。
    命令實例:

    java -jar hap-sign-tool.jar  sign-profile -keyAlias "openharmony application profile release" -signAlg "SHA256withECDSA" -mode "localSign" -profileCertFile "OpenHarmonyProfileRelease.pem" -inFile "UnsgnedReleasedProfileTemplate.json" -keystoreFile "OpenHarmony.p12" -outFile "app1-profile.p7b" -keyPwd "123456" -keystorePwd "123456"
    

    該命令的參數(shù)說明:

    sign-profile:簽名profile文件
        ├── -keyAlias         # 生成profile證書的密鑰別名,該參數(shù)必填且不能修改
        ├── -signAlg          # 簽名算法,包括 SHA256withECDSA / SHA384withECDSA,該參數(shù)必填
        ├── -mode             # 簽名模式,目前僅支持localSign,該參數(shù)必填
        ├── -profileCertFile  # Profile簽名證書,指定已提供的profile證書文件,該參數(shù)必填且不可修改
        ├── -inFile           # 輸入原始的模板Profile文件,文件為json格式,所在目錄為developtools_hapsigner/autosign/UnsgnedReleasedProfileTemplate.json,該參數(shù)必填
        ├── -keystoreFile     # 密鑰庫文件,指定使用提供的OpenHarmony.p12密鑰庫文件,該參數(shù)必填且不可修改
        ├── -outFile          # 輸出簽名后的profile文件,p7b格式,該參數(shù)必填
        ├── -keyPwd           # 密鑰口令,OpenHarmony.p12中的口令默認“123456”
        ├── -keystorePwd      # 密鑰庫口令,OpenHarmony.p12口令默認為“123456”
    
  4. 對應(yīng)用包進行簽名
    調(diào)用應(yīng)用包簽名接口,使用應(yīng)用簽名密鑰為應(yīng)用包簽名。
    命令實例:

    java -jar hap-sign-tool.jar sign-app -keyAlias "oh-app1-key-v1" -signAlg "SHA256withECDSA" -mode "localSign" -appCertFile "app1.pem" -profileFile "app1-profile.p7b" -inFile "app1-unsigned.zip" -keystoreFile "OpenHarmony.p12" -outFile "app1-signed.hap" -keyPwd "123456" -keystorePwd "123456"
    

    說明

    以下參數(shù)說明默認為無應(yīng)用簽名證書場景,當(dāng)開發(fā)場景為有應(yīng)用簽名證書場景時,下列參數(shù)需要修改: -keyAlias:密鑰別名,填寫已有應(yīng)用簽名證書對應(yīng)的密鑰別名,參數(shù)必填。 -appCertFile:應(yīng)用簽名證書,填寫已有的應(yīng)用簽名證書,參數(shù)必填。 -keystoreFile:密鑰庫文件,填寫已有應(yīng)用簽名證書對應(yīng)的密鑰庫文件,參數(shù)必填。 -keyPwd:密鑰口令,填寫密鑰庫文件中對應(yīng)密鑰的口令。 -keystorePwd:密鑰庫口令,填寫密鑰庫文件的密鑰口令。

    該命令的參數(shù)說明:

    sign-app:簽名應(yīng)用包
        ├── -keyAlias          # 密鑰別名,為第一步生成的密鑰信息別名,該參數(shù)必填
        ├── -signAlg           # 簽名算法,包括 SHA256withECDSA / SHA384withECDSA,該參數(shù)必填
        ├──  -mode             # 簽名模式,目前僅支持localSign,該參數(shù)必填
        ├──  -appCertFile      # 應(yīng)用簽名證書(證書鏈,順序為最終實體證書-中間CA證書-根證書),填寫第二步生成的應(yīng)用簽名證書,該參數(shù)必填
        ├──  -profileFile      # 簽名后的profile文件,p7b格式,填寫第三步中生成的profile文件,必填項
        ├──  -inFile           # 輸入原始應(yīng)用包文件,該參數(shù)必填
        ├──  -keystoreFile     # 密鑰庫文件,請與步驟一中密鑰庫文件保持一致,該參數(shù)必填且不可修改
        ├──  -outFile          # 輸出簽名后的包文件,必填項
        ├──  -keyPwd           # 密鑰口令,與第一步生成的密鑰對口令保持一致
        ├──  -keystorePwd      # 密鑰庫口令,與第一步的密鑰庫口令保持一致
    

常見問題

  1. 執(zhí)行第二步生成應(yīng)用簽名證書命令時,控制臺打印結(jié)果,無文件輸出。
    • 現(xiàn)象描述
      生成證書時,只在控制臺打印證書內(nèi)容,無對應(yīng)文件輸出。
    • 可能原因
      outFile參數(shù)中路徑不正確 和 '-outFile'中的'-'非英文格式。
    • 解決辦法
      檢查并修正outFile參數(shù)為正確路徑,'-outFile'中的'-'為英文格式
  2. 執(zhí)行第三步對profile文件進行簽名時,提示簽名失敗。
    • 現(xiàn)象描述
      現(xiàn)象分為以下幾種:
      (1)執(zhí)行命令后提示 "SIGN_ERROR, code: 107. Details: Failed to verify signature: Wrong key usage"
      (2)執(zhí)行命令后提示 "NOT_SUPPORT_ERROR, code: 105. Details: Profile cert 'resultprofile1.pem' must a cert chain"
      (3)執(zhí)行命令后提示 "VERIFY_ERROR, code: 108. Details: Failed to verify signature: unable to find valid certification path to requested target"
    • 可能原因
      (1)profile簽名證書(最終實體證書)證書鏈順序不正確。
      (2)profile簽名證書(最終實體證書)不是證書鏈。
      (3)證書主題順序不正確 或者 生成應(yīng)用簽名證書時“-issuerKeyAlias”參數(shù)填寫錯誤。
    • 解決辦法
      (1)檢查并修正證書鏈順序,只能正序或反序,不可亂序。
      (2)檢查簽名時的最終實體證書是否為證書鏈。
      (3)檢查證書主題順序是否正確,順序須為C、O、OU、CN。
  3. 對應(yīng)用包進行簽名時提示簽名錯誤。
    • 現(xiàn)象描述
      執(zhí)行命令后提示:NOT_SUPPORT_ERROR, code: 105. Details: SignAlg params is incorrect, signature algorithms include SHA256withECDSA,SHA384withECDSA。
    • 可能原因
      簽名算法不支持,signAlg參數(shù)填寫錯誤。
    • 解決辦法
      最終實體證書密鑰對推薦使用ECC生成,hap簽名算法修改為ECC對應(yīng)的SHA256withECDSA,SHA384withECDSA。
  4. 簽名應(yīng)用包失敗,提示證書CN字段為空。
    • 現(xiàn)象描述
      執(zhí)行命令后提示:error: Common name of certificate is empty! 。
    • 可能原因
      當(dāng)前使用的應(yīng)用包簽名證書,不包含CN字段,導(dǎo)致簽名失敗。
    • 解決辦法
      根據(jù)業(yè)界證書規(guī)范,應(yīng)用包簽名證書的CN字段必須不為空,請重新生成格式正確的證書。

審核編輯 黃宇

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

    關(guān)注

    25

    文章

    3728

    瀏覽量

    16403
  • 鴻蒙OS
    +關(guān)注

    關(guān)注

    0

    文章

    189

    瀏覽量

    4459
收藏 人收藏

    評論

    相關(guān)推薦

    企業(yè)鴻蒙原生應(yīng)用元服務(wù)備案實操名公鑰簽名信息

    一、 鴻蒙應(yīng)用/元服務(wù)如何查詢名? 登錄 AppGallery Connect ,點擊“我的應(yīng)用”,輸入應(yīng)用名稱可查詢到需要備案的鴻蒙應(yīng)用/元服務(wù)名。 二、
    發(fā)表于 04-10 15:32

    USB開發(fā)指導(dǎo)資料

    USB開發(fā)指導(dǎo)資料[hide][/hide]
    發(fā)表于 04-17 00:00

    【HarmonyOS】HarmonyOS子系統(tǒng)開發(fā)指導(dǎo)

    子系統(tǒng)開發(fā)主要從三個方面進行指導(dǎo),分別是圖形圖像類子系統(tǒng)開發(fā)指導(dǎo),相機子系統(tǒng)開發(fā)指導(dǎo)和音視頻子系統(tǒng)開發(fā)指導(dǎo)。圖形圖像容器類組件
    發(fā)表于 09-21 14:50

    鴻蒙工具

    鴻蒙工具鴻蒙的概念了解得差不多了,就該開始嘗試著去接觸它。這份鴻蒙工具主要是針對開發(fā)板的
    發(fā)表于 11-24 11:28

    #HarmonyOS征文#—鴻蒙OS開發(fā)流程及DevEco Studio安裝

    鴻蒙OS的完整開發(fā)流程1. 注冊并實名認證華為開發(fā)者賬號鴻蒙官網(wǎng):www.harmonyos.com注冊登錄華為賬號后,進行實名認證登錄之后
    發(fā)表于 07-22 11:43

    鴻蒙智聯(lián)生態(tài)產(chǎn)品《接入智慧生活A(yù)pp開發(fā)指導(dǎo)》(官方更新版)

    特意整理出“接入智慧生活A(yù)pp”專題。跟緊小編的步伐,趕緊來看看本次文檔更新內(nèi)容~ 文檔中心-接入智慧生活A(yù)pp的開發(fā)指導(dǎo): https://device.harmonyos.com/cn
    發(fā)表于 04-26 15:00

    OpenHarmony應(yīng)用Hap簽名

    了非常友好的hap自動簽名功能,以及非常便捷的Debug發(fā)布。由于IDE的安全密碼要求,對于Release的發(fā)布我們暫時需要手動簽名,尤其是系統(tǒng)級的應(yīng)用。我們可以利用官方提供的
    發(fā)表于 09-20 09:18

    OpenHarmony應(yīng)用HAP簽名

    便捷的Debug。由于IDE的安全密碼要求,對于Release的發(fā)布我們暫時需要手動簽名,尤其是系統(tǒng)級的應(yīng)用。我們可以利用官方提供的簽名工具
    發(fā)表于 10-13 17:11

    鴻蒙 OS 應(yīng)用開發(fā)初體驗

    Setup HarmonyOS-SDK:鴻蒙操作系統(tǒng)軟件開發(fā)工具包 Previewer:預(yù)覽器 Toolchains:工具鏈 OpenHarmony-SDK:開源鴻蒙操作系
    發(fā)表于 11-02 19:38

    基于GoKit的產(chǎn)品開發(fā)指導(dǎo)

    基于GoKit的產(chǎn)品開發(fā)指導(dǎo),有板子的可以下載看看的
    發(fā)表于 11-16 19:00 ?0次下載

    ZigBee2007視頻教程-應(yīng)用開發(fā)指導(dǎo)

    ZigBee2007視頻教程-應(yīng)用開發(fā)指導(dǎo)ZigBee2007視頻教程-應(yīng)用開發(fā)指導(dǎo)ZigBee2007視頻教程-應(yīng)用開發(fā)指導(dǎo)ZigBee2007視頻教程-應(yīng)用開發(fā)指導(dǎo)
    發(fā)表于 12-29 10:31 ?19次下載

    TI DM388評估模塊和開發(fā)開發(fā)指導(dǎo)手冊

    TI DM388評估模塊和開發(fā)開發(fā)指導(dǎo)手冊
    發(fā)表于 11-25 18:06 ?15次下載

    MCGS腳本驅(qū)動開發(fā)工具使用指導(dǎo)手冊下載

    MCGS腳本開發(fā)指導(dǎo)手冊
    發(fā)表于 02-08 13:45 ?85次下載

    UM2388_STM32Cube固件開發(fā)指

    UM2388_STM32Cube固件開發(fā)指
    發(fā)表于 11-22 08:21 ?3次下載
    UM2388_STM32Cube固件<b class='flag-5'>包</b>的<b class='flag-5'>開發(fā)指</b>南

    使用 Taro 開發(fā)鴻蒙原生應(yīng)用 —— 快速上手,鴻蒙應(yīng)用開發(fā)指

    鴻蒙原生應(yīng)用。 在 《使用 Taro 開發(fā)鴻蒙原生應(yīng)用》 系列文章中,我們已經(jīng)介紹了 鴻蒙的基本概念 和 Taro 適配鴻蒙的原理。本文作
    的頭像 發(fā)表于 02-02 16:09 ?903次閱讀
    使用 Taro <b class='flag-5'>開發(fā)</b><b class='flag-5'>鴻蒙</b>原生應(yīng)用 —— 快速上手,<b class='flag-5'>鴻蒙</b>應(yīng)用<b class='flag-5'>開發(fā)指</b>南
    主站蜘蛛池模板: 免费看片aⅴ免费大片| 男人天堂网在线| 2021av网站| 国产精品久久久久久一级毛片| 黄色毛片基地| 中国成人免费视频| 在线电影天堂| 五月婷婷激情综合| 日本xxxx色视频在线观看| 欧美色视频日本片高清在线观看| 免费一级毛片视频| 国产盗摄女子私密保健视频| www.色com| 日日夜操| jlzzjlzz欧美大全| 亚洲国产视频网| 中文字幕色| 色噜噜亚洲| 黄色片视频网| 日韩亚洲人成在线综合| 在线观看黄色网| 1024人成软件色www| 一级毛片ab片高清毛片| 日本三级中文字幕| 国产一二精品| 小视频国产| 成人亚洲精品| 久久久噜噜噜久久| 欧美freesex交| 国产精品九九久久一区hh | 日本aaaa级毛片在线看| 性色a v 一区| 免费网站你懂得| 2014天堂| 波多野结衣50连精喷在线| 中文一区二区在线观看| 中文字幕一区二区三区永久| 看黄网站免费| 日本三级视频在线观看| 高清色| 久热九九|