
Android 7.0中引入了APK Signature Scheme v2,v1呢是jar Signature來自JDK
V1:應(yīng)該是通過ZIP條目進行驗證,這樣APK 簽署后可進行許多修改 - 可以移動甚至重新壓縮文件。
V2:驗證壓縮文件的所有字節(jié),而不是單個 ZIP 條目,因此,在簽名后無法再更改(包括 zipalign)。正因如此,現(xiàn)在在編譯過程中,我們將壓縮、調(diào)整和簽署合并成一步完成。好處顯而易見,更安全而且新的簽名可縮短在設(shè)備上進行驗證的時間(不需要費時地解壓縮然后驗證),從而加快應(yīng)用安裝速度。
解決方案一
v1和v2的簽名使用
只勾選v1簽名并不會影響什么,但是在7.0上不會使用更安全的驗證方式
只勾選V2簽名7.0以下會直接安裝完顯示未安裝,7.0以上則使用了V2的方式驗證
同時勾選V1和V2則所有機型都沒問題
解決方案二
在app的build.gradle的android標簽下加入如下
signingConfigs?{??
????debug?{ ?
v1SigningEnabledtrue ?
v2SigningEnabledtrue??
????}??
????release?{??
v1SigningEnabledtrue??
v2SigningEnabledtrue??
????}??
}??