Apk签名,每一个Android开发者都不陌生。它就是对我们的apk加了一个校验参数,防止apk被掉包。一开始做Android开发,就接触到了apk签名;后来在微信开放平台、高德地图等平台注册时,需要填写apk签名的md5值和sha256值;再后来做系统应用,接触到了系统签名;而后就想了解下apk的生成机制,学习了如何用命令行进行签名。很早时以为很简单的签名,真没想到也蕴含这么丰富的知识,就想整理一下,也分享给其它小伙伴们。

文章结构:

利用Android Studio生成签名与对apk进行签名

获取签名文件的md5值和sha256值

获取系统签名

利用命令行生成签名与对apk进行签名

一、利用Android Studio生成签名与对apk进行签名

利用Android Studio(或者Eclipse)生成签名与对apk进行签名,是最常用的签名方式。本文也就从这里开始说起。

1.生成签名

依次选择Build——Generate Signed Bundle/APK——选择apk——点击Next,会看到Key store path下面有两个按钮(如图1)。

我们这里是要生成签名,当然选择Create New…,打开New Key Store对话框(如图2),填入指定的信息后,点击OK即可生成签名。

2.对apk进行签名

打开Generate Signed Bundle or APK对话框后,直接选择已有的签名即可,点击Next,选择输出路径、签名版本后,点击Finish即可生成签名后的版本。

3.Android Studio2.2之后的V1签名和V2签名

当使用Android Studio2.2及以后版本进行签名打包时,会发现多了一个对签名版本的选择(如图3),这个V1和V2表示什么意思呢?

V1就是传统的签名方式,V2则是Android7.0之后引入的。其区别是,V1是通过ZIP条目进行验证,这样APK 签署后可进行许多修改;而V2验证压缩文件的所有字节,而不是单个 ZIP 条目,这样在签名后无法再更改。V2的好处很明显,更安全且验证更迅速。所以,推荐在生成apk时,签名方式选择V1+V2。当然,仅仅选择V1也是可以的。如果仅选择V2呢,这样生成的apk在Android7.0及之后的版本上没有问题,不过会导致7.0以下的版本无法安装,所以要避免这种方式。

4.在gradle中配置签名信息

我们都知道Android使用gradle来构建版本,因此我们也希望在gradle中配置好签名信息,在打包apk时更方便。

在项目的build.gradle中,android下加入signingConfig信息。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

signingConfigs {

debug {

storeFile file("./hyydev.jks")

storePassword "******"

keyAlias "**"

keyPassword "******"

v1SigningEnabled true

v2SigningEnabled true

}

release {

storeFile file("./hyydev.jks")

storePassword "******"

keyAlias "**"

keyPassword "******"

v1SigningEnabled true

v2SigningEnabled true

}

}

5.jks与keystore

从Eclipse开始做Android开发的小伙伴都知道,Eclipse默认生成的签名文件是keystore格式,而Android Studio生成的是jks格式。二者只是签名格式的不同,是可以进行转换的(如何转换,后续会专门介绍)。

二、获取签名文件的md5值和sha256值

在文章开始时,就提到了在许多开放平台注册时,需要用到apk签名的md5值和sha256值,怎么获取呢?这里提供了两种方法。

1.用命令行获取md5值和sha256值

1

keytool -v -list -keystore hyydev.jks

如图4。

2.用代码获取md5值和sha256值

除了用keytool命令获取外,也可以通过代码获取签名的md5值和sha256值。

代码如下:

1

2

3

4

5

6

7

8

9

10

11大专栏  Android apk签名详解——AS签名、获取签名信息、系统签名、命令行签名n>

12

13

14

15

16

17

18

public static String getSign(Context context, String packageName) {

String signValidString = "";

try {

@SuppressLint("PackageManagerGetSignatures")

PackageInfo packageInfo = context.getPackageManager().getPackageInfo(packageName, PackageManager.*GET_SIGNATURES*);

signValidString = *getSignValidString*(packageInfo.signatures[0].toByteArray(), "MD5");  //参数可以填"SHA1"、"SHA256"

} catch (Exception e) {

}

return signValidString;

}

private static String getSignValidString(byte[] paramArrayOfByte, String signType) throws NoSuchAlgorithmException {

MessageDigest localMessageDigest = MessageDigest.*getInstance*(signType);

localMessageDigest.update(paramArrayOfByte);

return *toHexString*(localMessageDigest.digest());  //转为16进制显示,实现略去

}

三、获取系统签名

Android系统的签名信息不是keystore或jks格式,它默认存在buildtargetproductsecurity目录下(如图5)。如果需要获取系统签名的信息,需要在Ubuntu环境下把它转换为keystore或jks格式。

1.生成keystore签名文件

1>.取platform.pk8 platform.x509.pem放到一个目录下

2>.生成platform.pem

1

openssl pkcs8 -in platform.pk8 -inform DER -outform PEM -out platform.pem -nocrypt

3>.生成platform.p12

1

2

3

openssl pkcs12 -export -in platform.x509.pem -inkey platform.pem -out platform.pk12 -name dev

Enter Export Password: (输入密码,比如hyydev)

Verifying - Enter Export Password:(输入密码,比如hyydev)

4>.生成hyysign.keystore

1

keytool -importkeystore -deststorepass android -destkeypass hyydev -destkeystore hyysign.keystore -srckeystore platform.pk12 -srcstoretype PKCS12 -srcstorepass hyydev -alias dev

2.生成jks签名文件

与生成keystore文件类似。

1>.取platform.pk8 platform.x509.pem放到一个目录下

2>.生成platform.pem文件

1

openssl pkcs8 -inform DER -nocrypt -in platform.pk8 -out platform.pem

3>.生成platform.p12

1

openssl pkcs12 -export -in platform.x509.pem -out platform.p12 -inkey platform.pem -password pass:hyydev -name hyy

4>.生成hyysign.jks

1

keytool -importkeystore -deststorepass hyydev -destkeystore hyysign.jks -srckeystore platform.p12 -srcstoretype PKCS12 -srcstorepass hyydev

3.哪些apk的签名必须使用系统签名文件

有些apk需要系统权限,比如实现关机指令。

如何声明系统权限呢?

在AndroidMainfest.xml的mainfest中加入:

1

android:sharedUserId="android.uid.system"

用到系统权限的apk,起签名必须使用系统签名,否则安装不上,会报错误(如图6)。

四、利用命令行生成签名与对apk进行签名

上面所提到的签名,都是利用IDE来生成签名、进行签名,用命令行该怎么做呢?

1.生成签名

1

keytool -genkeypair -alias hyydev -keyalg RSA -validity 400 -keystore hyydev.keystore

2.对未签名的apk进行签名

1

jarsigner -verbose -keystore hyydev.keystore -signedjar TestSign.apk Test.apk hyydev

3.重签名

进行重签名时,会报错java.util.zip.ZipException: invalid entry compressed size (expected 41278 but got 42575bytes) bytes)。如何解决呢?就是要重签名的apk后缀改成zip,打开后删除里面的META-INF目录,然后重新改成apk后缀,再进行签名就可以了。

Android签名详解(debug和release)

Android签名详解(debug和release)   1. 为什么要签名 1) 发送者的身份认证 由于开发商可能通过使用相同的Package Name来混淆替换已经安装的程序,以此保证签名不同的包 ...

Android 签名详解

Android 签名详解 AndroidOPhoneAnt设计模式Eclipse  在Android 系统中,所有安装 到 系统的应用程序都必有一个数字证书,此数字证书用于标识应用程序的作者和在应用程 ...

Android签名详解

1.什么是签名?      如果这个问题不是放在Android开发中来问,如果是放在一个普通的版块,我想大家都知道签名的含义.可往往就是将一些生活中常用的术语放在计算机这种专业领域,大家就开始迷惑了. ...

unity3d-配置Android环境,打包发布Apk流程详解

31:unity3d-配置Android环境,打包发布Apk流程详解 作者 阿西纳尼 关注 2016.08.28 22:52 字数 498 阅读 1806评论 0喜欢 5 Unity配置Android ...

JMessage Android 端开发详解

目前越来越多的应用会需要集成即时通讯功能,这里就为大家详细讲一下如何通过集成 JMessage 来为你的 App 增加即时通讯功能. 首先,一个最基础的 IM 应用会需要有哪些功能? 用户注册 / 登 ...

android:ToolBar详解

android:ToolBar详解(手把手教程) 泡在网上的日子 发表于 2014-11-18 12:49 第 124857 次阅读 ToolBar 42 来源 http://blog.mosil.b ...

Android SDK Manager详解

Android基础知识——Android SDK Manager详解   做Android开发时,免不了使用Android SDK Manager,安装需要的sdk版本.buildTools版本等等. ...

Android调试桥-Android Debug Birdge详解

原文:http://android.eoe.cn/topic/summary Android调试桥-Android Debug Birdge Android调试桥(adb)是一个多功能的命令行功具,它 ...

Android Fragment用法详解(2)--动态添加Fragment

在上一篇文章我们讲解了Fragment的最简单的用法.这次我们来说一说Fragment复杂一丢丢的用法.在代码 ...

随机推荐

linux下svn客户端报错Cannot negotiate authentication mechanism的解决方法

svn客户端报错Cannot negotiate authentication mechanism的解决方法: 问题出现的原因之一: 因为SVN服务器配置了saslauthd服务用来实现与ldap的对 ...

JS中的phototype是JS中比较难理解的一个部分

本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展.我们称B的原 ...

补习系列(3)-springboot中的几种scope

目标 了解HTTP 请求/响应头及常见的属性: 了解如何使用SpringBoot处理头信息 : 了解如何使用SpringBoot处理Cookie : 学会如何对 Session 进行读写: 了解如何在 ...

【UOJ#21】【UR#1】缩进优化

我好弱啊,什么题都做不出来QAQ 原题: 小O是一个热爱短代码的选手.在缩代码方面,他是一位身经百战的老手.世界各地的OJ上,很多题的最短解答排行榜都有他的身影.这令他感到十分愉悦. 最近,他突然发现 ...

Html5与Css3知识点拾遗(二)

页面title 选择能简要概括文档内容的文字作为title文字,title核心内容放在前60个字符 分级标题 1.创建分级标题时,避免跳过级别,如h3直接跳到h5,但允许从低级别跳到高级别. 2.不用 ...

Git 撤销与修改

增补提交 git commit –C HEAD –a --amend -C表示复用指定提交的提交留言,这个例子中是HEAD,实际上可以指定其他有效的提交名称. 如果参数是小写的-c,就会打开预先设置好 ...

Python3 open() 函数

Python3 open() 函数  Python3 内置函数 Python open() 方法用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 ...

C#用ckplayer.js播放 MP4格式视频实现 边加载边播放

MVC设计模式下 在View页面里面使用ckplayer.js 加载视频 ,在MP4格式视频上传之后 我发现某些视频可以边加载边播放 但是有一些又不行,找了下原因是因为视频的元数据信息在第一帧的时候就 ...

(转)Python中实现带Cookie的Http的Post请求

转自crifan: http://www.crifan.com/python_http_post_request_with_cookie/ . . . .

android获取系统签名,Android apk签名详解——AS签名、获取签名信息、系统签名、命令行签名...相关推荐

  1. Day13-Java方法详解,方法的定义、重载,命令行传参,可变参数与递归

    Java方法详解 什么是方法? Java的方法是语句的集合,他们在一起执行一个功能 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法再程序中被创建,在其他地方被引用 [方法原子性]一个方 ...

  2. SuseLinux详解(1)——设置开机启动为命令行模式

    目录 1.打开终端 2. 输入命令 3. 找到DISPLAYMANAGER, 将原有的注释掉,设置DISPLAYMANAGER="console" 4. 保存重启

  3. Virtual PC 2007下虚拟机与本机双XP系统实现互联与上网详解

    Virtual PC 2007下虚拟机与本机双XP系统实现互联与上网详解 1.在虚拟机安装windowsXP系统 2.为了不影响用来上网的原网卡,所以我们选择在主机上装一个虚拟网卡来与虚拟机进行通信, ...

  4. Linux系统中的软件管理详解(下)—搭建网络软件仓库及第三方软件仓库

    Linux系统中的软件管理详解(下) 5.软件仓库管理命令 a)dnf 命令: 管理软件仓库中的安装包 dnf repolist ##列出仓库信息clean all ##清除系统中已经加载的仓库缓存信 ...

  5. Android签名与校验过程详解

    原文:https://blog.csdn.net/gulinxieying/article/details/78677487 目 录 一.签名与校验原理概要    2 1.数字签名简介    2 2. ...

  6. android应用市场点击下载APK安装详解

    Android系统启动篇 1,<android系统启动流程简介> 2,<android init进程启动流程> 3,<android zygote进程启动流程> 4 ...

  7. Android 系统属性读取和设置详解

    Android 系统属性读取和设置详解 一.在adb中进行属性读取和设置 1.Settings Provider设置和读取 获取 设置 2.SystemProperties属性读取和设置 二.Andr ...

  8. Android系统(96)---Android 数据交换解析框架Gson使用详解

    Android 数据交换解析框架Gson使用详解 Json 是一种文本形式的数据交换格式,比 xml 更为轻量.Json 的解析和生成的方式很多,在 Android 平台上最常用的类库有 Gson 和 ...

  9. Android 8.0学习(32)---Android 8.0源码目录结构详解

    Android 8.0源码目录结构详解 android的移植按如下流程:     (1)android linux 内核的普通驱动移植,让内核可以在目标平台上运行起来.     (2)正确挂载文件系统 ...

  10. Android JNI使用方法,JNI机制详解

    Android JNI使用方法,JNI机制详解 JNI的出现使得开发者既可以利用Java语言跨平台.类库丰 富.开发便捷等特点,又可以利用Native语言的高效. JNI是JVM实现中的一部分,因此N ...

最新文章

  1. 总以为自己走的很快,才发现自己是走的最慢的那个
  2. 如何从Java中的字符串值获取枚举值?
  3. GODADDY主机用tar命令通过SSH远程打包20M以上的文件
  4. 使用matlab构建一个信号、添加噪声信号并图示信号
  5. [How TO]-Ubuntu 20.04修改终端标题栏文字
  6. Maximal Rectangle leetcode java
  7. ZeptoN正在将程序放入Java
  8. 关闭uboot MMU 会导致android2.3 S5pv210 系统不稳定?!why
  9. 10个绕过反病毒的恶意用户技巧
  10. java编译异常有哪些_java 中 哪些异常必须声明并捕获,否则产生编译错误
  11. MySQL用户的增删改权以及root远程连接
  12. oracle 修改列类型6,Oracle用户、权限、角色管理 编辑
  13. 50. 避免重定向(11)
  14. expect自动登录以及远程脚本执行
  15. java中常用的算法--URL
  16. lisp princ详解_晓东CAD家园-论坛-A/VLISP-正则表达式lisp实例讲解-通过代码,完整的展示了正则表达式在lisp中使用 - Powered by Discuz!...
  17. 特殊回文数 C++解法
  18. 关于注册时验证邮箱,并实现类似安卓的吐丝效果
  19. 2.5 随从受伤溅血效果的实现———自制卡牌游戏之旅
  20. 理解C语言中的a++、a--和++a、--a

热门文章

  1. 纯前端实现页面的回到顶部和回到底部功能
  2. 基础知识--pcre
  3. Android完美解决监听home键
  4. java seek_java中seek()的用法,seek和seekfor有什么区别
  5. 写出linux命令的功能,练习一LINUX命令测试题1
  6. 《论文阅读》FroDO: From Detections to 3D Objects
  7. 陌陌也出了网页版,醉翁之意不在酒在直播
  8. Python tkinter 设置主题
  9. Qt界面无法切换输入法的解决方法
  10. Qt---随机数生成器