当前位置: 首页 > 编程日记 > 正文

apk签名验证机制

声明:

1.本帖转载自:http://riusksk.blogbus.com/logs/272154406.html,仅供自用,勿喷

2.欢迎交流学习



签名后的APK,在/META-INF目录下会生成以下3个文件:


MANIFEST.MF:保存除META-INF文件以外其它各文件的SHA-1+base64编码后的值。

CERT.SF:在SHA1-Digest-Manifest中保存MANIFEST.MF文件的SHA-1+base64编码后的值,在后面的各项SHA1-Digest中保存MANIFEST.MF各子项内容SHA-1+Base64编码后的值

CERT.RSA/DSA/EC:保存用私钥计算出CERT.SF文件的数字签名、证书发布机构、有效期、公钥、所有者、签名算法等信息


Android应用签名验证过程中,满足以下条件才能安装应用:

1、SHA-1(除META-INF目录外的文件)  ==  MANIFEST.MF中的各SHA-1值;

2、(SHA-1 + Base64)(MANIFEST.MF文件及各子项) ==  CERT.SF中各值

3、公钥(CERT.SF) == CERT.RSA/DSA对SF文件的签名

Android 中关于签名验证相关源码分析:

关键源码主要位于:

http://code.metager.de/source/xref/android/4.4/frameworks/base/core/java/android/content/pm/PackageParser.java

http://code.metager.de/source/xref/android/4.4/libcore/luni/src/main/java/java/util/jar/JarVerifier.java

1、读取DSA/RSA/EC后缀的签名证书文件,然后调用verifyCertificate进行难,此处并无限制文件名,因此将CERT.RSA改成CERT123.RSA依然有效,但SF文件得跟RSA文件等签名证书文件同名:

2、读取SF(与后面证书同名)与RSA/DSA/EC文件的内容,再调用verifySignature进行校验:

3、在verifySignature进行校验时会去读取各项证书信息,包括证书序列号、拥有者、加密算法等等,然后判断CERT.RSA证书对CERT.SF的文件签名是否正确,防止CERT.SF被篡改,若成功则返回证书链,否则抛出异常:

4、在返回证书链时,对于自签名证书,则直接作为合法证书返回

5、继续回到verifyCertificate函数,它会校验SF文件中的MANIFEST.MF中各项Hash值是否正确,防止MF文件被篡改:

6、对于非系统应用,去枚举除META-INF目录以外的所有文件,然后进行哈希运算,并将其与MANIFEST.MF中的各文件哈希值进行比对,只有相匹配后才允许安装应用:


转载于:https://www.cnblogs.com/JianXu/p/5158413.html

相关文章:

spring cloud微服务分布式云架构--hystrix的使用

hystrix主要作用在服务消费者,进行应用的保护,当请求的服务请求超时时,做出相应的处理,避免客户端一直进行请求等待,避免在高并发的情况出现服务器死机(请求过多,内存不足) 接下来的…

JSP项目目录中每个文件夹及配置文件的作用

/WEB-INF目录:Web应用应用部署目录,浏览客户是看不到该目录下的文件的,该目录下的文件专供Web服务器专用。web.xml:部署描述文件,/WEB-INF目录下最重要的文件,它描述了程序的部署、配置信息,为W…

java里锛是什么意思,java实验总结

p3person.newperson("jane", 13, f);System.out.println(p1);System.out.println(p2);System.out.println(p3);}}1. 设计一个数据单元类DataUnit, 它包含学号(Number)和姓名(Name)两个数据成员。2. 设计两个线程,一个线程往数据单元里写信息,一…

c调用python

tables.py global gtablesgtables { 1001:"张鲁p", 1002:"凌p", 2001:"李进a", 2002:"vb" } from tables import gtables def get_cmd(key, value): name "0"; try: name gtables[key] …

梦美生命获1亿元A轮融资,鼎晖领投

3月20日消息,跨境辅助生殖医疗IVF服务的企业梦美生命(下称:梦美)已获得约1亿人民币A轮融资,由鼎晖领投,淡蓝及天使投资方开牛投资跟投,本轮融资主要用于人才引进以及市场推广。 梦美成立于2013…

网站锁定php文件命令,PHP文件锁定读写的一点注意_php

都说文本方式容易出现文件锁定失效等乱七八糟的问题.其实并不是失效, 而是写法有些不对.被 lock_ex 后的文件 再以read模式 fopen 的话将读到空内容!!!如果没有判断就把它作操作后再写入就出错啦....很多问题出在这里.再来补充一下如果一个文件被以write的模式fopen后并 flock(…

luogu P1280 尼克的任务 序列DP

我们发现&#xff0c;我们从前往后DP有苦难&#xff0c;因为现在的选择存在后效性。 如果我们从后向前DP&#xff0c;f[i]表示从i时刻到下班的最小工作时间&#xff0c;从后向前转移&#xff0c;则不存在后效性问题。 1 #include <cstdio>2 #include <vector>3 usi…

第一次使用cookie

给招行做的一个小游戏&#xff0c;有个需求是&#xff1a;分数第一次达到500会弹出一个提示框。之前没有使用过cookie&#xff0c;在网上搜了些资料&#xff0c;最终还是顺利实现了功能。在这里贴一下代码。 <%! //初始化cookiepublic String getCookie(HttpServletRequest …

保证你现在和未来不失业的10种关键技【转载】

在当今的IT就业市场&#xff0c;有人欢喜有人忧。有人对目前的工作和薪水很满意&#xff0c;有人目前正面临着下岗&#xff0c;或者已经下岗…… 可能你是公司里唯一谙熟某项关键技术的高手&#xff0c;缺了你&#xff0c;公司便玩不转了&#xff1b;也可能你所在的公司对你现…

MySQL建表枚举分区SQL,【mysql备份】02、Xtrabackup备份mysql

一、Xtrabackup概述1、Xtrabackup简介Xtrabackup是由percona提供的mysql数据库备份工具&#xff0c;据官方介绍&#xff0c;这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具。官网&#xff1a;https://www.percona.com/InnoDB存储引擎支持热备&#xff0c…

CentOS目录结构超详细版

最近初学Linux 对linux的目录产生了很多疑问&#xff0c;看到这篇文章&#xff0c;让我顿时对目录有了一个清晰的认识&#xff01;推荐给大家&#xff01; ----------------------------------------------------------------------------------------------------------------…

02_计算机科学和软件工程的区别

计算机科学和软件工程同属计算机类专业&#xff0c;他们的联系确实非常紧密&#xff0c;但还是有很多区别的。 计算机科学&#xff1a; 偏重于硬件与计算机理论方面的学习研究&#xff0c;像计算机原理&#xff0c;计算机系统结构等方面的内容。当然也会涉及软件方面&#xff0…

来自 Google 的 R 语言编码风格指南

来自 Google 的 R 语言编码风格指南 R 语言是一门主要用于统计计算和绘图的高级编程语言. 这份 R 语言编码风格指南旨在让我们的 R 代码更容易阅读、分享和检查. 以下规则系与 Google 的 R 用户群体协同设计而成. 概要: R编码风格约定文件命名: 以 .R (大写) 结尾标识符命名: v…

php中去空函数trim,PHP中trim()函数简单使用指南

string trim ( string $str [, string $charlist ] ) - 去除字符串首尾处的空白字符(或者其他字符)trim()函数当第二个参数为空时&#xff0c;默认去掉空格、制表符、换行符、回车符、垂直制表符等&#xff0c;当加入第二个参数时复制代码 代码如下:1) trim( \"string\&…

03 基本数据类型、运算符 输入输出

代码注释 单行注释&#xff1a;# 多行注释&#xff1a;可以用三对双引号""" """ 基本数据类型 事物的状态有不同的种类&#xff0c;使用不同类型的值去记录不同的状态 一、数字类型 1.整型int 定义&#xff1a;age10 #ageint(10)作用&#xff1…

wordpress调用树形目录

wordpress调用树形结构目录最简单的方法就是使用方法就是使用函数&#xff1a;<?php wp_list_categories( $args ); ?>另一种方法&#xff0c;方便自定义样式,代码如下&#xff1a;<div class"rightbox"><div class" cat_right_bg cat_title&…

php类方法语法错误捕获,php语法错误捕获

PHP语法错误捕获处理一般捕获错误使用的方法是&#xff1a;try{...}catch(Exception $e){echo $e->getMessage();}或者set_exception_handler(function ($exception) {echo $exception->getMessage();});示例&#xff1a;<?php function test(){throw new Exception(…

2019BATJ面试题详解:MyBatis+MySQL+Spring+Redis+多线程

这里为大家分享一些面试的一手资料&#xff0c;供大家迎接接下来的金三银四跳槽季SpringSpring 概述什么是spring?使用Spring框架的好处是什么&#xff1f;Spring由哪些模块组成&#xff1f;解释AOP模块Spring配置文件什么是Spring IOC 容器&#xff1f;依赖注入什么是Spring的…

高手讲解PHP遍历数组的方法

在PHP中数组分为两类&#xff1a; 数字索引数组和关联数组。其中数字索引数组和C语言中的数组一样&#xff0c;下标是为0&#xff0c;1&#xff0c;2…而关联数组下标可能是任意类型&#xff0c;与其它语言中的hash&#xff0c;map等结构相似。 下面介绍PHP中遍历关联数组的三…

QQ拼音在中文输入下默认英文标点

别小看这个功能, 感觉在写一些技术 Blog 的情况下还是挺有用的. 打开QQ拼音: 输入法设置->基本设置->初始状态->中文状态下使用英文标点. 转载于:https://www.cnblogs.com/qrlozte/p/4904087.html

matlab在输电线路故障测距中应用,Matlab在输电线路故障测距中的应用.doc

Matlab在输电线路故障测距中的应用毕业设计(论文)题目 Matlab在输电线路故障测距中的应用二级学院 电子信息与自动化学院专 业 电气工程及其自动化班 级 110070401学生姓名 施永平 学号 11007990223指导教师 雷绍兰 职称 教授时 间2014年2月24日至6月10日目录摘要IAbstractII1绪…

AES数据加密传输

问题&#xff1a;当数据调用没有使用https加密时&#xff0c;app被抓包&#xff0c;接口暴露&#xff0c;此时可能导致被刷等安全问题 解决&#xff1a;1. 使用https传输 2. 在进行数据传输时进行手动加密&#xff08;app端和后端定义统一的加密方式&#xff09;&#xff0c;这…

Java 线程 笔记(1)

线程是一个程序内部的顺序控制流 线程和进程的区别&#xff1a; 1. 每个进程都有独立的代码和数据空间&#xff08;进程上下文&#xff09;&#xff0c;进程间的切换会有较大的开销 2. 线程可以看成是轻量级的进程&#xff0c;同一类的线程共享代码和数据空间&#xff0c;每个…

smartcrop.js智能图片裁剪库

今天将为大家介绍一款近期github上很不错的开源库 – smartcrop.js。它是一款图片处理的智能裁剪库。在很多项目开发中&#xff0c;经常会遇见上传图片的场景&#xff0c;它可能是用户照片信息&#xff0c;也可能是商品图片等。然而在网页布局中&#xff0c;为了更好的用户体验…

golang 解析php序列化,golang实现php里的serialize()和unserialize()序列和反序列方法详解...

Golang 实现 PHP里的 serialize() 、 unserialize()安装go get -u github.com/techleeone/gophp/serialize用法package mainimport ("fmt""github.com/techleeone/gophp/serialize")func main() {str : a:1:{s:3:"php";s:24:"世界上最好的语…

HotSpot模板解释器目标代码生成过程源码分析

虽然说解释执行模式是逐字逐句翻译给目标平台运行的&#xff0c;但这样的过程未免太过缓慢&#xff0c;如果能把字节码说的话做成纸条&#xff0c;运行时只要把对应的纸条交给目标平台就可以了&#xff0c;这样&#xff0c;执行速度就会明显提升。JVM的Hotspot虚拟机的模板解释…

flex--unable to transcode image

很低级的解决啊&#xff0c;把那个.png文件用画图打开后&#xff0c;重新用png格式保存了下就好咧。。。 转载于:https://www.cnblogs.com/avenxia/archive/2012/04/24/2468334.html

svn服务器发生变更,如何切换

参考链接&#xff1a; https://blog.csdn.net/jk110333/article/details/9301283 https://blog.csdn.net/emtit2008/article/details/51498012 svn switch --relocate svn://旧IP地址/项目 svn://新IP地址/项目 如果是windows客户端,直接在工作副本上右键&#xff0c;选择Torto…

泛型java博客园,Java深度历险之Java泛型

Java泛型(generics)是JDK 5中引入的一个新特性&#xff0c;允许在定义类和接口的时候使用类型参数(type parameter)。声明的类型参数在使用时用具体的类型来替换。泛型最主要的应用是在JDK 5中的新集合类框架中。对于泛型概念的引入&#xff0c;开发社区的观点是褒贬不一。从好…

EXCEL-XML 代码相对行列转换绝对

这段时间因为工作的要求&#xff0c;需要在程序中处理xml 格式的excel 文档。但是在期间遇到了一个问题就是Row 和 Cell 的index 属性相对绝对的问题。 之前在bing 找了一下没找到介绍相对转换成绝对的资料。在经过多次的尝试和对比在空白的文档中不同的cell 中输入值后的XML文…