android签名命令行,android 使用命令行打包签名

打包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

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的值。

验证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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值