Android Studio 打包時 Signature Version 選擇 V1 V2 說明


 

問題描述(v1和v2)

Android 7.0中引入了APK Signature Scheme v2,v1是jar Signature來自JDK
V1:應該是通過ZIP條目進行驗證,這樣APK 簽署后可進行許多修改 - 可以移動甚至重新壓縮文件。
V2:驗證壓縮文件的所有字節,而不是單個 ZIP 條目,因此,在簽名后無法再更改(包括 zipalign)。正因如此,現在在編譯過程中,我們將壓縮、調整和簽署合並成一步完成。好處顯而易見,更安全而且新的簽名可縮短在設備上進行驗證的時間(不需要費時地解壓縮然后驗證),從而加快應用安裝速度。


解決方案一

v1和v2的簽名使用
1)只勾選v1簽名並不會影響什么,但是在7.0上不會使用更安全的驗證方式
2)只勾選V2簽名7.0以下會直接安裝完顯示未安裝,7.0以上則使用了V2的方式驗證
3)同時勾選V1和V2則所有機型都沒問題

解決方案二
在app的build.gradle的android標簽下加入如下

[java]  view plain  copy
  在CODE上查看代碼片 派生到我的代碼片
  1. signingConfigs {  
  2.     debug {  
  3.         v1SigningEnabled true  
  4.         v2SigningEnabled true  
  5.     }  
  6.     release {  
  7.         v1SigningEnabled true  
  8.         v2SigningEnabled true  
  9.     }  
  10. }  


官方解釋:
態度
  • 個人建議:

這是一個從Android7.0系統出現的新的簽名機制,這個新機制使得apk的簽名方式更加安全,首先我們應該嘗試把V1和V2兩個選項全部勾選,並盡可能的去使用他們,但是如果全部勾選完畢出現了問題,那么我們可以忽略這種新的簽名機制,只勾選第一個選項(V1),依舊使用我們之前老的簽名機制。







免責聲明!

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



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