美文网首页
android 使用命令行打包签名

android 使用命令行打包签名

作者: RoboyCore | 来源:发表于2017-06-13 17:42 被阅读199次
    • 打包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 使用命令行打包签名

          本文链接:https://www.haomeiwen.com/subject/wlfjqxtx.html