美文网首页
Android系统签名

Android系统签名

作者: casual_v | 来源:发表于2020-07-27 00:19 被阅读0次

    长话短说,有时候我们的应用需要用到系统签名才能调用一些方法,那么就需要在清单上加uid

    <manifest  xmlns:android="http://schemas.android.com/apk/res/android"
                package="com.xxxx.xxxx"
               android:sharedUserId="android.uid.system">
    ...
    </manifest>
    

    一般这种情况都是apk在Android板上开发,板子供应商大多数都是提供一个3个文件(signapk.jar,platform.x509.pem,platform.pk8)让你去签名,有的是跑脚本,有的是给一个exe
    实际上都是跑这段代码

    java -jar signapk.jar platform.x509.pem platform.pk8 未签名.apk 签名.apk
    

    这种生成一个apk后再需要工具去引入系统签名的方法,是极其的不方便,公司是使用jenkins打包,操作人员不可能会去做这些事情
    那么我们可以在gradle上弄task,让jenkins打包的时候,去引入系统签名
    前提条件是,打包的电脑需要配置git 为系统变量,不然跑不了sh文件
    方法如下:
    在项目中新一个signtools目录,然后将板子供应商提供的文件放到同一个目录下


    4370ED5CAEB0B7F352B856160A9A2799.jpg

    sh文件内容如下:

    #!/bin/sh
    # apk源文件路径
    origin=$1
    output=$2
    java -jar ./signapk.jar ./platform.x509.pem ./platform.pk8 ${origin} ${output}
    

    接下来就是编辑gradle文件
    新建立一个task autosign
    跟android同级


    263ECDDA3348D4F8DDDBB60CD0A5FACF.png

    build.finalizedBy 'autoSign'
    意思是让jenkins执行build之后执行签名

    task autoSign {
    //    dependsOn('assembleRelease')
        doLast {
            //签名文件目录
            def signDir = project.rootDir.absolutePath + "/signtools/"
            def shPath = signDir + "sign.sh"
            println("signDir----" + signDir)
            android.applicationVariants.all { variant ->
                variant.outputs.all { output ->
                    //获取 apk打包出来的文件 output.outputFile
                    def exist = output.outputFile.exists()
                    if (exist) {
                        //签名后的apk输出目录  其实就是 debug或者 release
                        def outputDir = output.outputFile.parent
                        //签名之后的apk名字
                        def name = "/Signed_" + output.outputFile.getName()
                        //apk打包所在的目录
                        def oldApk = output.outputFile.getPath()
                        println("outputDir----" + outputDir)
                        println("name----" + name)
                        println("oldApk----" + oldApk)
                        println("shPath----" + shPath)
                        exec {
                            //切换到sh文件所在的目录,执行脚本
                            workingDir signDir
                            //执行shell脚本 "," 传参
                            commandLine 'sh', shPath, oldApk, outputDir + name
                            println("The signature is successful and the file is saved to:")
                            println(outputDir + name)
                            println("-----------------------------------")
                        }
                        //删掉原来未签名的apk
                        output.outputFile.delete();
                    }
                }
            }
        }
    }
    

    这样一来,自动构建就能顺便系统签名了
    但是呢,新的问题又来了,这仅仅是方便了别人,但是开发自己依旧蛋疼,难道我每次都要这样执行一下签名任务???我想点run直接install 已经签名的包,怎么搞?
    一开始我也迷,但是换个切入点即可,我们可以将原来的签名文件引入系统签名,那样直接就一劳永逸,也不用去跑什么task了
    你需要下载keytool-importkeypair
    https://github.com/getfatday/keytool-importkeypair
    使用起来也比较的简单,找到系统的 platform.pk8 和 platform.x509.pem 放在 keytool-importkeypair目录下

    D135A06A4B72404CD486CB83C87C0850.png

    执行:

    ./keytool-importkeypair -k ./demo.keystore -p password123 -pk8 platform.pk8 -cert platform.x509.pem -alias aaaa
    

    这里或许你会懵逼,怎么执行???
    其实需要安装git,然后在keytool-importkeypair目录下右键git bash here


    E52BD077265CF415213FCE0BA51FF694.jpg
    signingConfigs {
        releaseConfig {
            keyAlias 'aaaa'
            keyPassword 'password123'
            storeFile file("../demo.keystore")
            storePassword 'password123'
        }
    }
    

    这里需要注意一点,如果不存在demo.keystore 执行命令后会直接生成一个,如果已经有demo.keystore会提示是否覆盖
    然后将生成的keystore替换原来项目上的keystore,那就能直接用了
    end~

    相关文章

      网友评论

          本文标题:Android系统签名

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