获取Android签名证书的公钥和私钥的简单实例
作者:jingxian 发布时间:2022-10-02 22:20:13
标签:公钥,私钥,签名,android
本文以Android签名JKS格式的证书为例:
package com.test;
import java.io.FileInputStream;
import java.security.Key;
import java.security.KeyStore;
import java.security.PrivateKey;
import java.security.PublicKey;
import javax.crypto.Cipher;
public class SignTest {
public static void main(String[] args) {
try {
// 用证书的私钥解密 - 该私钥存在生成该证书的密钥库中
FileInputStream fis2 = new FileInputStream("G:\\shanhytest.keystore");
KeyStore ks = KeyStore.getInstance("JKS"); // 加载证书库
char[] kspwd = "shanhytest".toCharArray(); // 证书库密码
char[] keypwd = "shanhytest".toCharArray(); // 证书密码
String alias = "shanhytest";// 别名
ks.load(fis2, kspwd); // 加载证书
PrivateKey privateKey = (PrivateKey) ks.getKey(alias, keypwd); // 获取证书私钥
PublicKey publicKey = ks.getCertificate(alias).getPublicKey();// 获取证书公钥
fis2.close();
System.out.println("privateKey = " + getKeyString(privateKey));
System.out.println("publicKey = " + getKeyString(publicKey));
// 测试加密解密字符串
String srcContent = "今天天气不错。";
// 将字符串使用公钥加密后,再用私钥解密后,验证是否能正常还原。
// 因为非对称加密算法适合对小数据量的数据进行加密和解密,而且性能比较差,所以在实际的操作过程中,我们通常采用的方式是:采用非对称加密算法管理对称算法的密钥,然后用对称加密算法加密数据,这样我们就集成了两类加密算法的优点,既实现了加密速度快的优点,又实现了安全方便管理密钥的优点。
byte[] d1 = crypt(publicKey, srcContent.getBytes(), Cipher.ENCRYPT_MODE);
byte[] d2 = crypt(privateKey, d1, Cipher.DECRYPT_MODE);
System.out.println(new String(d2));
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 将KEY转换为字符串
*
* @param key
* @return
* @author SHANHY
*/
private static String getKeyString(Key key) {
byte[] keyBytes = key.getEncoded();
String s = new String(org.apache.commons.codec.binary.Base64.encodeBase64(keyBytes));
return s;
}
/**
* 加密/解密
*
* @param key
* 私钥打包成byte[]形式
* @param data
* 要解密的数据
* @param opmode
* 操作类型(Cipher.DECRYPT_MODE为解密,Cipher.ENCRYPT_MODE为加密)
* @return 解密数据
*/
public static byte[] crypt(Key key, byte[] data, int opmode) {
try {
long startTime = System.currentTimeMillis();
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");//jdk默认标准
// Cipher cipher = Cipher.getInstance("RSA/ECB/NoPadding");// android默认标准
cipher.init(opmode, key);
byte[] result = cipher.doFinal(data);
System.out.println((Cipher.DECRYPT_MODE==opmode?"解密":"加密") + "耗时:" + (System.currentTimeMillis() - startTime));
return result;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
0
投稿
猜你喜欢
- PathVariable 映射 URL 绑定的占位符带占位符的 URL 是 Spring3.0 新增的功能,该功能在SpringMVC 向
- JAVA中获取文件MD5值的四种方法其实都很类似,因为核心都是通过JAVA自带的MessageDigest类来实现。获取文件MD5值主要分为
- 本项目使用的环境:开发工具:Intellij IDEA 2017.1.3springboot: 1.5.6jdk:1.8.0_161mave
- 在c和c++中,我们知道没办法起一个变量名叫int,因为这是C/C++保留的关键字,起这么一个变量名没办法区分到底是int类型还是int变量
- 登陆是系统最基础的功能之一。这么长时间了,一直在写业务,这个基础功能反而没怎么好好研究,都忘差不多了。今天没事儿就来撸一下。以目前在接触和学
- 一、添加插件apply plugin: 'maven-publish'二、添加如下配置//打包源码task sourceJa
- 引言大家应该都知道,对Excel表格设置分页对我们预览、打印文档时是很方便的,特别是一些包含很多复杂数据的、不规则的表格,为保证打印时每一页
- 1.for循环import com.google.common.base.Function;import com.google.common
- /** * @param h *
- BASE64 编码是一种常用的字符编码,在很多地方都会用到。但base64不是安全领域下的加密解密算法。能起到安全作用的效果很差,而且很容易
- 本文实例讲述了java实现word文档转pdf并添加水印的方法。分享给大家供大家参考,具体如下:前段时间,项目需要自动生成word文档,用W
- 在 C# 以二进制形式读取数据时使用的是 BinaryReader 类。BinaryReader 类中提供的构造方法有 3 种,具体的语法形
- 近来,很多公司的APP都实现了人脸识别登录的功能。今天呢,银鹏带大家从头到尾做一下这个人脸识别登录。首先呢,我们需要采用一个拥有人脸识别算法
- 1. 什么是XGBoostXGBoost是陈天奇等人开发的一个开源机器学习项目,高效地实现了GBDT算法并进行了算法和工程上的许多改进,被广
- 安装 小试记一次使用arthas排查jvm中CPU占用过高问题。这工具 * 爆了 碾压我目前使用的全部JVM工具。curl -O https:/
- 1.首先解释一下什么是方法重载?方法重载是指在同一个类中方法同名,参数不同,调用时根据实参的形式,选择与他匹配的方法执行操作的一种技术。这里
- 本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下推荐视频:尚硅谷Spring Data JPA视频教程,
- 1. ObsoleteAttributeObsoleteAttribute 适用于除组件、模块、参数和返回值以外的所有程序元素。将元素标记为
- 一、Drools引擎简介1、基础简介Drools是一个基于java的规则引擎,开源的,可以将复杂多变的规则从硬编码中解放出来,以规则脚本的形
- 目录实现效果实现方式实现步骤Blend绘制Path绘制Path绘制直线绘制曲线改变曲线形状移除Path上的线段移除Path上的点Path添加