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
    
  1. 验证签名

     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

你可能感兴趣的:(android 使用命令行打包签名)