- 打包Jar
jar cvf a.jar b.java c.java 将b和c打包到a.jar中
或者使用 jar cvf a.jar * 当前目录全部打包到a.jar
-
打包 Release
./gradlew assembleRelease --stacktrace 发布Release包
如果只想为该工程下的某个模块打包
./gradlew :newhealthylife:assembleRelease
- 生成签名
keytool -genkey -keystore ./keyfile.keystore -keyalg RSA -validity 10000 -alias yan
//注:validity为天数,keyfile为生成key存放的文件,yan为私钥,RSA为指定的加密算法(可用RSA或DSA)
-
为包签名
jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 –keystore $[cis.jks](签名文件)$[/Users/mima123/IdeaProjects/cis-android/newhealthylife/build/outputs/apk/cn.com.cis.newhealthy.apk ](文件apk) $[cis.com.cn](别名) exp: jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore cis.jks /Users/mima123/IdeaProjects/cis-android/newhealthylife/build/outputs/apk/cn.com.cis.newhealthy.apk cis.com.cn
-
验证签名
jarsigner -verbose -certs -verify /Users/mima123/IdeaProjects/cis-android/newhealthylife/build/outputs/apk/cn.com.cis.newhealthy.apk
apksigner verify -v xxx.apk //查看签名信息
android有自带签名的DOS命令 : jarsigner -verbose -keystore [您的私钥存放路径] -signedjar [签名后文件存放路径] [未签名的文件路径] [您的证书名称]
此命令各参数含义如下:
jarsigner -verbose -keystore zdd.keystore -signedjar aaa.apk
bbb.apk xhwl
jarsigner -verbose:签名命令标识符。
-keystore:后面跟着的是你签名使用的密钥文件(keystore)的绝对路径。
-signedjar:此后有三个参数:
参数一:签名后生成的apk文件所要存放的路径。
参数二:未签名的apk文件的存放路径。
参数三:你的证书名称,通俗点说就是你keystore文件的别名,那这个别名怎么查看?其实就是在你eclipse进行签名打包时的Alias的值。
- Apktool
apktool
apktool d -r -f xx. apk //解包
apktool b xx.apk //构包
- zipalign
zipalign -v 4 in.apk out.apk //4字节对齐优化
zipalign -c -v 4 in.apk //检查APK是否对齐
//zipalign可以在V1签名后执行 但zipalign不能在V2签名后执行,只能在V2签名之前执行!!!
- 验证zipalign对齐
zipalign -c -v 4 xxx.apk //在Sdk\build-tools\28.0.0中
通过properties传递签名信息
1、在module的根目录下新建signing.properties文件
STORE_FILE = ./keystore.jks
STORE_PASSWORD = your password
KEY_ALIAS =
your password
KEY_PASSWORD = your password
注意:此处没有”“
2、在module的build.gradle中创建
android {
signingConfigs {
release {
storeFile
storePassword
keyAlias
keyPassword
}
}
//调用配置文件
getSigningProperties()
}
buildTypes {
debug {
minifyEnabled true
zipAlignEnabled false
shrinkResources false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
release {
minifyEnabled true //混淆
zipAlignEnabled true //Zipalign优化
shrinkResources true // 移除无用的resource文件
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
**//注意要添加签名
signingConfig signingConfigs.release**
//自定义apk名字
applicationVariants.all { variant ->
variant.outputs.each { output ->
output.outputFile = new File(
output.outputFile.parent,
"应用前缀${variant.buildType.name}-${defaultConfig.versionName}-${releaseTime()}-${variant.productFlavors[0].name}.apk".toLowerCase())
}
}
}
}
如果需要时间的话,需要增加一个函数releaseTime()
//获取时间
def releaseTime() {
return new Date().format("yyyy-MM-dd", TimeZone.getTimeZone("UTC"))
}
注意:函数需要放在android{}外面
3、读取配置文件
///读取签名配置文件 这个需要放在android{}外面
def getSigningProperties(){
def propFile = file('signing.properties')
if (propFile.canRead()){
def Properties props = new Properties()
props.load(new FileInputStream(propFile))
if (props!=null && props.containsKey('STORE_FILE') && props.containsKey('STORE_PASSWORD') &&props.containsKey('KEY_ALIAS') && props.containsKey('KEY_PASSWORD')) {
android.signingConfigs.release.storeFile = file(props['STORE_FILE'])
android.signingConfigs.release.storePassword = props['STORE_PASSWORD']
android.signingConfigs.release.keyAlias = props['KEY_ALIAS']
android.signingConfigs.release.keyPassword = props['KEY_PASSWORD']
} else {
println 'signing.properties found but some entries are missing'
android.buildTypes.release.signingConfig = null
}
}else {
println 'signing.properties not found'
android.buildTypes.release.signingConfig = null
}
}
4、命令打包
//这个是打包所有渠道release版本./gradlew assembleRelease
//如果你只要打某个渠道的./gradlew assembleBaiduRelease
三:总结
1、打包后的apk文件在app–>build–>outputs—>apk中2、使用gradlew时可能出现没有找到该命令,需要chmod 755 gradlew