当前位置: 首页 > article >正文

Android系统定制APP开发_如何对应用进行系统签名

前言

当项目开发需要使用系统级别权限或frame层某些api时,普通应用是无法使用的,需要在AndroidManifest中配置sharedUserId:
AndroidManifest.xml中的android:sharedUserId=“android.uid.system”,代表的意思是和系统相同的uid,可以拥有修改系统时间,文件操作等权限。

1.制作Android Studio可以使用的jks文件

1.1 下载keytool-importkeypair
链接: https://download.csdn.net/download/u010345983/87453083

1.2 将keytool-importkeypair文件拷贝到platform签名所在目录
Android原生的签名会区分user和userdebug,配置目录分别如下:
(1)user的签名配置在:build\target\product\security\release
(2)userdebug的签名配置在:build\target\product\security

签名文件在Android源码的位置如下

build/target/product/security/platform.pk8
build/target/product/security/platform.x509.pem

其中,.pk8文件为私钥,.x509.pem文件为公钥

1.3 执行命令生成jks文件

./keytool-importkeypair -k longzhiye.jks -p pwd123 -pk8 platform.pk8 -cert platform.x509.pem -alias longzhiye

-k:生成的jks密钥文件
-p:密码
-alias:密钥别名

2.将上述生成的jks文件填到AndroidStudio的build.gradle文件中

在工程主模块的 \app\build.gradle文件中添加 signingConfigs 签名配置信息

android {

    defaultConfig {
        ...
    }

    signingConfigs {
        release {
            storeFile file("./longzhiye.jks")
            keyAlias 'longzhiye'
            keyPassword 'pwd123'
            storePassword 'pwd123'
            v2SigningEnabled true
        }
        debug {
            storeFile file("./longzhiye.jks")
            keyAlias 'longzhiye'
            keyPassword 'pwd123'
            storePassword 'pwd123'
            v2SigningEnabled true
        }
    }

    buildTypes {
        ...
    }

}

构建脚本配置完成后,使用Android Studio执行指定的构建时,就会按照我们写好的脚本信息生成对应签名的apk。

3.密钥安全性

为了保障密钥的安全, 不建议将密钥文件上传至代码管理平台,也不建议将密钥文件的别名、密码直接以明文的方式写到build.gradle中。


http://www.kler.cn/a/507796.html

相关文章:

  • 攻防世界 unseping
  • vue2配置跨域后请求的是本机
  • [Mac + Icarus Verilog + gtkwave] Mac运行Verilog及查看波形图
  • HCIP-VLAN-hybrid接口+DHCP实验
  • 【Flink系列】4. Flink运行时架构
  • 静态综合路由实验
  • Android 北斗与平台芯片相关
  • PLC(电力载波通信)网络机制介绍
  • Qt——QTableWidget 限制单元格输入范围的方法(正则表达式输入校验法、自定义代理类MyItemDelegrate)
  • Go语言strings包与字符串操作:从基础到高级的全面解析
  • C#深度神经网络(TensorFlow.NET)
  • MongoDB中游标的使用
  • 2019-Android-高级面试题总结-从java语言到AIDL使用与原理
  • ctfshow复现2024ciscn第一场web
  • Leetcode 91. 解码方法 动态规划
  • DATACOM-STP、RSTP、MSTP-复习-实验
  • 简历_使用优化的Redis自增ID策略生成分布式环境下全局唯一ID,用于用户上传数据的命名以及多种ID的生成
  • 【Python】Selenium根据网页页面长度,模拟向下滚动鼠标,直到网页底部的操作
  • UI Automation 中所有Patterns
  • [WUSTCTF2020]Cr0ssfun
  • Nginx(搭建高可用集群)
  • 如何使用WPS的JS宏实现Word表格的自动编号
  • Open3D 计算每个点的协方差矩阵【2025最新版】
  • improve-gantt-elastic(vue2中甘特图实现与引入)
  • 软考信安25~移动应用安全需求分析与安全保护工程
  • blackbox_exporter 如何检测端口