Android 系统签名打包方法

Android 系统签名打包方法方式一命令行生成(推荐):此方式不需要配置,步骤也不多。1、在应用程序manifest.xml文件根节点中加入属性:Android:sharedUserId=“android.uid.system”;2、在android系统目录build/target/product/security/拷贝系统签名文件:platform.x509.pem、platform.pk8;3、在out/host/linux-x86/framework目录下找到signapk.jar文件;4、把三个文件(plat

大家好,又见面了,我是你们的朋友全栈君。

方式一 命令行生成(推荐)
此方式不需要配置,步骤也不多。

1、在应用程序manifest.xml文件根节点中加入属性:Android:sharedUserId=“android.uid.system”;

2、在android系统目录build/target/product/security/拷贝系统签名文件:platform.x509.pem、platform.pk8;

3、在out/host/linux-x86/framework目录下找到signapk.jar文件;

4、把三个文件(platform.x509.pem、platform.pk8、signapk.jar)放在一个文件夹下,再把需要系统签名的test.apk也放在该文件下。

5、window cmd 路径要在引导(cd)该文件夹下,利用签名工具signapk.jar修改应用程序签名:命令为:java -jar signapk.jar platform.x509.pem platform.pk8 test.apk testsign.apk

方式二 更改AS 打包配置:
此方式配置繁琐,但一劳永逸,适合频繁打包的场景
使用keytool-importkeypair工具
原理:
就是通过Android studio 直接给 apk 加上开发者签名(jks文件),使用 keytool-importkeypair 对jks文件进行系统签名,在出包的时候,直接使用带有系统签名的 jks 对 apk 进行签名,这样编译生成的 apk 文件就自带系统签名了

1、使用Android studio 生成你自己的 jks 文件,如下图;

在这里插入图片描述
如果,之前没有的就新建,点击Create New … 设置密码(易记,建议123456),如下图:

在这里插入图片描述

 然后Next – Finish

2、使用keytool-importkeypair对jks文件引入系统签名
把platform.x509.pem、platform.pk8和上一部生成的jks文件统一放到一个文件夹下,比如我的是放在工程目录的 signAPK目录下

在这里插入图片描述
将下载好的keytool-importkeypair配置一下,其实主要就是配置一下环境变量,不熟悉的可以阅读官方文档,然后使用下面这条命令(需要在linux下,用windows的可以去在linux下生成jks,然后复制出新的jks回原目录也可以)对jks文件引入系统签名:

 ./keytool-importkeypair -k [jks文件名] -p [jks的密码] -pk8 platform.pk8 -cert platform.x509.pem -alias [jks的别名]

例如我的对应的就是:
./keytool-importkeypair -k SignDemo.jks -p 123456 -pk8 platform.pk8 -cert platform.x509.pem -alias SignDemo

运行完这条命令之后,我们就得到了有系统签名的jks。

keytool-importkeypair工具下载链接:https://github.com/getfatday/keytool-importkeypair

3、配置gradle(app)
在Android区域下(与defaultConfig同级)添加signingConfigs配置:
依次填写jks的路径,密码,别名等

apply plugin: ‘com.android.application’

android {

    compileSdkVersion 23
    buildToolsVersion “23.0.2”

    defaultConfig {

        applicationId “com.cxq.signdemo”
        minSdkVersion 19
        targetSdkVersion 23
        versionCode 1
        versionName “1.0”
    }
    signingConfigs {

        release {

            storeFile file(“../signApk/SignDemo.jks”)
            storePassword ‘123456’
            keyAlias ‘SignDemo’
            keyPassword ‘123456’
        }

        debug {

            storeFile file(“../signApk/SignDemo.jks”)
            storePassword ‘123456’
            keyAlias ‘SignDemo’
            keyPassword ‘123456’
        }
    }
    buildTypes {

        release {

            minifyEnabled false
            proguardFiles getDefaultProguardFile(‘proguard-android.txt’), ‘proguard-rules.pro’
        }
    }
}

dependencies {

    compile fileTree(dir: ‘libs’, include: [‘*.jar’])
    testCompile ‘junit:junit:4.12’
    compile ‘com.android.support:appcompat-v7:23.3.0’
}

4、运行 

经过以上配置之后,以后每次直接点击run,app 就可以带着系统签名,直接安装到设备上了

本文转载自:https://blog.csdn.net/cui130/article/details/89451422

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151958.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月21日 上午10:16
下一篇 2022年6月21日 上午10:16


相关推荐

  • 一篇文章 玩转OpenClaw

    一篇文章 玩转OpenClaw

    2026年3月15日
    2
  • align_corners 的意义

    align_corners 的意义上采样层 upsamplelaye 是语义分割等密集输出 densepredict 任务的必备组件 一般默认选择双线性插值 bilinear 或者最近邻 nearest 的方式 这两种方式在 pytorch 的 interpolate 函数中均有实现 关于它们如何实现 已有好多博客解读 但是 bilinear 情况下 会伴随一个选项 align corners 默认为 False 关于这个选项的含义 pytorch1 3 1 官网是如下解释的 这个解释看起来令人似懂非懂

    2026年3月19日
    2
  • Linux常用命令操作详解

    Linux常用命令操作详解

    2021年10月29日
    51
  • 面试题springboot启动流程_Spring boot面试

    面试题springboot启动流程_Spring boot面试SpringBoot启动原理1、什么是SpringBoot2、SpringBoot启动原理3、三个关键注解解析3.1、@SpringBootConfiguration注解解析1、什么是SpringBootSpringBoot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,SpringBoot致力于在蓬勃发展的快速应用开发领域(RapidApplication

    2025年9月28日
    3
  • 智谱发布GLM-4-0414 系列模型、规模提升至 32B、包含多种能力

    智谱发布GLM-4-0414 系列模型、规模提升至 32B、包含多种能力

    2026年3月12日
    2
  • K8s认证_ce安全认证是什么意思

    K8s认证_ce安全认证是什么意思k8s访问控制概述Role只能对命名空间的资源进行授权,需要指定namespaceClusterRole可以对集群范围内的资源、跨namespace的范围资源、非资源类型进行授权RoleBinding可以将同一namespace中的subject对象绑定到某个Role下,则此Subject具有该Role定义的权限ClusterRoleBinding在整个集群级别和所有namespaces将特定的subject与ClusterRole绑定,授予权限虽然authorization-clusterrole是一个集

    2022年8月9日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号