android 打包签名

1. Android打包

打包就是根据签名和其他标识生成安装包

2. 签名

  1. 在android应⽤⽂件(apk)中保存的⼀个特别字符串
  2. ⽤来标识不同的应⽤开发者:开发者A还是开发者B
  3. ⼀个应⽤开发者开发的多款应⽤可使⽤同⼀个签名

Android系统要求每⼀个Android应⽤程序必须要经过数字签名才能够安装到系统中,也就是说如果⼀个Android应⽤程
序没有经过数字签名,是没有办法安装到系统中的!

3. 如何为apk签名

3.1选择Generate Signed Bundle /APK...



3.2 选择生成不同格式的安装包



aab与apk是不同Android安装包格式,目前上架google pay的app必须是要aab格式的安装包。

3.3 选择签名文件


3.4 创建新签名问题


*** 注意:在as中,签名文件keystore类型已为jks格式的文件***

3.5 选择已存在签名文件


3.6 生成签名安装包


在项目的app目录有一个release或者debug目录会生成对应的apk或aab文件
注意: debug环境生产安装包对外是不能安装的

  • V1 和V2签名的区别

    从Android 7.0开始, 谷歌增加新签名方案 V2 Scheme (APK Signature);
    但Android 7.0以下版本, 只能用旧签名方案 V1 scheme (JAR signing)

    V1 签名是 jar signature
    来自JDK (jarsigner), 对zip 压缩包的每一个文件进行验证, 签名后还能对压缩包进行修改(移动/重新压缩文件)
    对 V1 签名的apk/jar 解压,在meta-INF 存放签名的文件(MANIFEST.MF, CERT.SF, CERT.RSA)其中 MANIFEST.MF 文件保存所有文件的SHA1 指纹(除了META-INF文件), 由此可知, V1 签名是对压缩包中单个文件签名验证

    V2 签名是 Full apk signature
    来自Google(apksigner), 对zip压缩包的整个文件验证, 签名后不能修改压缩包(包括zipalign),对V2签名的apk解压,没有发现签名文件,重新压缩后V2签名就失效, 由此可知: V2签名是对整个APK签名验证

V2签名优点很明显:
签名更安全(不能修改压缩包)
签名验证时间更短(不需要解压验证),因而安装速度加快
注意: apksigner工具默认同时使用V1和V2签名,以兼容Android 7.0以下版本

4. apk应用加固

4.1 应用加固
在实际应用对外的apk为了安全起见,都会对apk文件进行加固,加固可以更好为移动应用代码保护技术如下

  • 反编译与反汇编保护
  • 客户端防篡改保护
  • 客户端防注入保护
  • 客户端反调试保护
  • 客户端本地数据与资源文件加密保护
  • SO 库绑定保护
  • 运行时环境检测技术
    目前我在使用是腾讯云的加固平台 [https://cloud.tencent.com]上传、下载。但是加固后还需要进行重新签名

4.2 应用加固

在本地新建一个文件把签名问价demo.jks文件和下载加固后的app.apk文件放在同目录下


签名命令

apksigner sign --ks demo.jks --out demo.apk app.apk

签名后的demo.apk就可以上传到官网或者应用市场了

签名命令

apksigner verify demo.apk

查看签名命令

keytool -v -list -keystore demo.jks

5. aab和apk有什么区别

  • aab(Android App Bundle)支持模块化,结合Google Play的动态支付(Dynamic Delivery)功能,将一个apk文件差分成多个apk,按照需要加载内容(包括加载C/C++ libraries),这样开发者可以随时按照需要交付功能,而不是仅限在安装过程中。
  • apk(Android application package)需要将所有内容打包成为一个被Android系统所能识别的文件,才可以被运行,一个apk文件内包含被编译的代码文件(.dex 文件),文件资源(resources), 原生资源文件(assets),证书(certificates),和清单文件(manifest file)。
  • 严格来说,两者没有什么区别,后者是前者的一种升级版格式文件。升级后的aab文件优势在于应用体积更小、拥有更安全的密钥签名等,可以让数据更加安全,避免病毒感染。

5.1 abb转化为apk
下载bundletool-all-1.9.1.jar 文件 下载地址如下:
https://www.aliyundrive.com/s/2eihhjgJnfz 提取码: 44iw

把base.aab、base.jks、bundletool-all-1.9.1.jar 放在同一个目录下。执行命令

--mode=universal          //生成文件apk文件名称
--bundle=base.aab       //as打包文件
--output=test.apks        //base.aab 生成的压缩包文件
--ks=base.jks               //签名文件
--ks-pass=pass:demo@demo    //签名文件密码
--ks-key-alias=demo                   //签名文件别名

此时就可以或得一个test.apks的压缩包,解压这个压缩包就有一个universal.apk


6. 修改签名

6.1 修改keystore密码的命令(keytool为JDK带的命令行工具)

 keytool -storepasswd -keystore demo.jks

输入密钥库口令: 原密码
新keystore password:新密码
其中,demo.jks是复制出来的证书文件,执行后会提示输入证书的当前密码,和新密码以及重复新密码确认

6.2 修改keystore的[alias]

keytool -changealias -keystore demo.jks  -alias oldalias -destalias newalias

这一步中,demo.jks是文件证书,oldalias是证书中当前的alias,-destalias指定的是要修改为的alias,这里按规矩来,改为newalias!这个命令会先后提示输入keystore的密码和当前alias的密码。

6.3 修改alias的密码

keytool -keypasswd -keystore demo.jks -alias newalias

输入密钥库口令: 原密码
新<newalias> 的密钥口令:新密码

这一步执行后会提示输入keystore密码,alias密码,然后提示输入新的alias密码!

6.3 获取md5的命令
keytool -exportcert -keystore demo.keystore | openssl dgst -md5

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容