AS打包簽名之V1(Jar Signature)和V2(Full APK Signature)


Android 7.0中引入了APK Signature Scheme V2,而V1來自JDK。

兩者區別:

V1:僅驗證未解壓的文件內容,這樣APK 簽署后可進行許多修改 ,可以移動甚至重新壓縮文件。

V2:驗證壓縮文件的所有字節,而不是單個 ZIP 條目,因此,在簽名后無法再更改(包括 zipalign)。 正因如此,現在在編譯過程中,我們將壓縮、調整和簽署合並成一步完成。

V2的好處:更安全而且新的簽名可縮短在設備上進行驗證的時間(不需要費時地解壓縮然后驗證), 從而加快應用安裝速度。如有任何自定義任務篡改 APK 文件或對其進行后處理(無論以任何方式), 那么V2 簽名會有作廢的風險,從而導致您的 APK 與 Android 7.0 及更高版本不兼容。

使用總結:

1、打包簽名時只勾選V1簽名並不會影響什么,但是在7.0及以上不會使用更安全的驗證方式;

2、只勾選V2簽名7.0以下安裝會直接顯示未安裝,7.0及以上則使用V2的方式驗證;

3、同時勾選V1和V2則所有機型都沒問題。

為了方便我們每次打包,我們可以設置每次打包默認兩個都勾選。在app所對應的build.gradle添加如下配置,再sync即可。
signingConfigs { debug { v1SigningEnabled true v2SigningEnabled true } release { v1SigningEnabled true v2SigningEnabled true } }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM