欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android中APK簽名工具之jarsigner和apksigner詳解

 更新時間:2018年06月13日 10:43:17   作者:lioil.win  
這篇文章主要給大家介紹了關(guān)于Android中APK簽名工具之jarsigner和apksigner的相關(guān)資料,文中介紹的非常詳細(xì),對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一.工具介紹

jarsigner是JDK提供的針對jar包簽名的通用工具,

位于JDK/bin/jarsigner.exe

apksigner是Google官方提供的針對Android apk簽名及驗證的專用工具,

位于Android SDK/build-tools/SDK版本/apksigner.bat

不管是apk包,還是jar包,本質(zhì)都是zip格式的壓縮包,所以它們的簽名過程都差不多(僅限V1簽名),

以上兩個工具都可以對Android apk包進(jìn)行簽名.

1.V1和V2簽名的區(qū)別

在Android Studio中點(diǎn)擊菜單 Build->Generate signed apk... 打包簽名過程中,

可以看到兩種簽名選項 V1(Jar Signature)  V2(Full APK Signature),

剛開始升級AS看到這個懵了,既然是APK Signature,就放心偷懶選了V2,結(jié)果安裝失?。???無奈,只能查資料...

從Android 7.0開始, 谷歌增加新簽名方案 V2 Scheme (APK Signature);

但Android 7.0以下版本, 只能用舊簽名方案 V1 scheme (JAR signing)

V1簽名:

  • 來自JDK(jarsigner), 對zip壓縮包的每個文件進(jìn)行驗證, 簽名后還能對壓縮包修改(移動/重新壓縮文件)
  • 對V1簽名的apk/jar解壓,在META-INF存放簽名文件(MANIFEST.MF, CERT.SF, CERT.RSA),
  • 其中MANIFEST.MF文件保存所有文件的SHA1指紋(除了META-INF文件), 由此可知: V1簽名是對壓縮包中單個文件簽名驗證

V2簽名:

  • 來自Google(apksigner), 對zip壓縮包的整個文件驗證, 簽名后不能修改壓縮包(包括zipalign),
  • 對V2簽名的apk解壓,沒有發(fā)現(xiàn)簽名文件,重新壓縮后V2簽名就失效, 由此可知: V2簽名是對整個APK簽名驗證

V2簽名優(yōu)點(diǎn)很明顯:

  • 簽名更安全(不能修改壓縮包)
  • 簽名驗證時間更短(不需要解壓驗證),因而安裝速度加快

注意: apksigner工具默認(rèn)同時使用V1和V2簽名,以兼容Android 7.0以下版本

2.zipalign和V2簽名

位于Android SDK/build-tools/SDK版本/zipalign.exe

zipalign 是對zip包對齊的工具,使APK包內(nèi)未壓縮的數(shù)據(jù)有序排列對齊,從而減少APP運(yùn)行時內(nèi)存消耗

zipalign -v 4 in.apk out.apk //4字節(jié)對齊優(yōu)化
zipalign -c -v 4 in.apk  //檢查APK是否對齊

zipalign可以在V1簽名后執(zhí)行

但zipalign不能在V2簽名后執(zhí)行,只能在V2簽名之前執(zhí)行?。?!

二.簽名步驟

1.生成密鑰對(已有密鑰庫,可忽略)

Eclipse或Android Studio在Debug時,對App簽名都會使用一個默認(rèn)的密鑰庫:

  •     默認(rèn)在C:\Users\用戶名\.android\debug.keystore
  •     密鑰庫名:   debug.keystore
  •     密鑰別名:   androiddebugkey
  •     密鑰庫密碼: android

1.生成密鑰對

    進(jìn)入JDK/bin, 輸入命令 

    keytool -genkeypair -keystore 密鑰庫名 -alias 密鑰別名 -validity 天數(shù) -keyalg RSA

    參數(shù):

        -genkeypair  生成一條密鑰對(由私鑰和公鑰組成)
        -keystore    密鑰庫名字以及存儲位置(默認(rèn)當(dāng)前目錄)
        -alias       密鑰對的別名(密鑰庫可以存在多個密鑰對,用于區(qū)分不同密鑰對)
        -validity    密鑰對的有效期(單位: 天)
        -keyalg      生成密鑰對的算法(常用RSA/DSA,DSA只用于簽名,默認(rèn)采用DSA)
        -delete      刪除一條密鑰

    提示: 可重復(fù)使用此條命令,在同一密鑰庫中創(chuàng)建多條密鑰對

    例如:     

        在debug.keystore中新增一對密鑰,別名是release

  keytool -genkeypair -keystore debug.keystore -alias release -validity 30000

2.查看密鑰庫

    進(jìn)入JDK/bin, 輸入命令

    keytool -list -v -keystore 密鑰庫名

    參數(shù):

        -list 查看密鑰列表
        -v    查看密鑰詳情

    例如:

  keytool -list -v -keystore debug.keystore

        現(xiàn)在debug.keystore密鑰庫中有兩對密鑰, 別名分別是androiddebugkey release

2.簽名

1.方法一(jarsigner,只支持V1簽名)

    進(jìn)入JDK/bin, 輸入命令

    jarsigner -keystore 密鑰庫名 xxx.apk 密鑰別名

    從JDK7開始, jarsigner默認(rèn)算法是SHA256, 但Android 4.2以下不支持該算法,

    所以需要修改算法, 添加參數(shù) -digestalg SHA1 -sigalg SHA1withRSA

    jarsigner -keystore 密鑰庫名 -digestalg SHA1 -sigalg SHA1withRSA xxx.apk 密鑰別名

    參數(shù):

        -digestalg  摘要算法
        -sigalg     簽名算法

    例如:

        用JDK7及以上jarsigner簽名,不支持Android 4.2 以下

  jarsigner -keystore debug.keystore MyApp.apk androiddebugkey

        用JDK7及以上jarsigner簽名,兼容Android 4.2 以下            

  jarsigner -keystore debug.keystore -digestalg SHA1 -sigalg SHA1withRSA MyApp.apk androiddebugkey

2.方法二(apksigner,默認(rèn)同時使用V1和V2簽名)

    進(jìn)入Android SDK/build-tools/SDK版本, 輸入命令

    apksigner sign --ks 密鑰庫名 --ks-key-alias 密鑰別名 xxx.apk

    若密鑰庫中有多個密鑰對,則必須指定密鑰別名

    apksigner sign --ks 密鑰庫名 --ks-key-alias 密鑰別名 xxx.apk

    禁用V2簽名

 apksigner sign --v2-signing-enabled false --ks 密鑰庫名 xxx.apk

    參數(shù):

        --ks-key-alias       密鑰別名,若密鑰庫有一個密鑰對,則可省略,反之必選
        --v1-signing-enabled 是否開啟V1簽名,默認(rèn)開啟
        --v2-signing-enabled 是否開啟V2簽名,默認(rèn)開啟

    例如:

        在debug.keystore密鑰庫只有一個密鑰對

  apksigner sign --ks debug.keystore MyApp.apk

        在debug.keystore密鑰庫中有多個密鑰對,所以必須指定密鑰別名

  apksigner sign --ks debug.keystore --ks-key-alias androiddebugkey MyApp.apk

3.簽名驗證

1.方法一(keytool,只支持V1簽名校驗)

    進(jìn)入JDK/bin, 輸入命令

 keytool -printcert -jarfile MyApp.apk (顯示簽名證書信息)

    參數(shù):

        -printcert           打印證書內(nèi)容
        -jarfile <filename>  已簽名的jar文件 或apk文件  

2.方法二(apksigner,支持V1和V2簽名校驗)

    進(jìn)入Android SDK/build-tools/SDK版本, 輸入命令

 apksigner verify -v --print-certs xxx.apk

    參數(shù):

        -v, --verbose 顯示詳情(顯示是否使用V1和V2簽名)
        --print-certs 顯示簽名證書信息

    例如:

  apksigner verify -v MyApp.apk

        Verifies
        Verified using v1 scheme (JAR signing): true
        Verified using v2 scheme (APK Signature Scheme v2): true
        Number of signers: 1

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • ReactNative Alert詳解及實例代碼

    ReactNative Alert詳解及實例代碼

    這篇文章主要介紹了ReactNative Alert詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • Android 實現(xiàn)簽到足跡功能

    Android 實現(xiàn)簽到足跡功能

    這篇文章主要介紹了Android 實現(xiàn)簽到足跡功能的示例,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下
    2021-04-04
  • Android實現(xiàn)跨進(jìn)程接口回掉的方法

    Android實現(xiàn)跨進(jìn)程接口回掉的方法

    這篇文章主要給大家介紹了關(guān)于Android如何實現(xiàn)跨進(jìn)程接口回掉的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Android  Wifi的forget()操作實例詳解

    Android Wifi的forget()操作實例詳解

    這篇文章主要介紹了Android Wifi的forget()操作實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Android Handler機(jī)制詳解原理

    Android Handler機(jī)制詳解原理

    Handler主要用于異步消息的處理:當(dāng)發(fā)出一個消息之后,首先進(jìn)入一個消息隊列,發(fā)送消息的函數(shù)即刻返回,而另外一個部分在消息隊列中逐一將消息取出,然后對消息進(jìn)行處理,也就是發(fā)送消息和接收消息不是同步的處理。 這種機(jī)制通常用來處理相對耗時比較長的操作
    2021-11-11
  • Android實現(xiàn)隨機(jī)圓形云標(biāo)簽效果

    Android實現(xiàn)隨機(jī)圓形云標(biāo)簽效果

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)隨機(jī)圓形云標(biāo)簽效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Android的activity學(xué)習(xí)筆記

    Android的activity學(xué)習(xí)筆記

    這篇文章主要整理了Android的activity學(xué)習(xí)筆記,總共有八大亮點(diǎn),推薦給大家,需要的朋友可以參考下
    2015-09-09
  • Android開發(fā)之關(guān)閉和打開Speaker(揚(yáng)聲器)的方法

    Android開發(fā)之關(guān)閉和打開Speaker(揚(yáng)聲器)的方法

    這篇文章主要介紹了Android開發(fā)之關(guān)閉和打開Speaker(揚(yáng)聲器)的方法,結(jié)合實例形式簡單分析了Android揚(yáng)聲器的操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-03-03
  • Android開發(fā)實現(xiàn)圖片大小與質(zhì)量壓縮及保存

    Android開發(fā)實現(xiàn)圖片大小與質(zhì)量壓縮及保存

    這篇文章主要為大家介紹了Android開發(fā)實現(xiàn)圖片大小與質(zhì)量壓縮及保存的方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • Android基于繪制緩沖實現(xiàn)煙花效果

    Android基于繪制緩沖實現(xiàn)煙花效果

    這篇文章主要介紹了Android基于繪制緩沖實現(xiàn)煙花效果,文中通過代碼示例和圖文結(jié)合介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,感興趣的同學(xué)可以自己動手嘗試一下
    2024-03-03

最新評論