博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
获取Android签名证书的公钥和私钥
阅读量:6714 次
发布时间:2019-06-25

本文共 2764 字,大约阅读时间需要 9 分钟。

本文以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 * @date 2015年11月21日 */ 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; }}

转载地址:http://dorlo.baihongyu.com/

你可能感兴趣的文章
洛谷P1435 回文字串(dp)
查看>>
php 会话控制(关于session的维护与生命周期)
查看>>
tomcat PermGen space
查看>>
高阶函数:声明、实现(定义)与调用
查看>>
splash 安装
查看>>
mysql数据库优化课程---15、mysql优化步骤
查看>>
数据库路由中间件MyCat - 使用篇(4)
查看>>
Java程序开发中的简单内存分析
查看>>
Java中的Future相关
查看>>
CGAL Catmull-Clark Subdivide Surface
查看>>
赛车入门 -- 专有技术名词
查看>>
接收IWebBrowser2的自动化事件
查看>>
需求入门: 需求工程=需求开发+需求管理
查看>>
androidmanifest.xml权限中文说明
查看>>
matlab练习程序(感知哈希对比图片)
查看>>
多媒体指令(图像灰度化)
查看>>
sqlserver数据库大型应用解决方案总结
查看>>
枚举系统设备
查看>>
C#形参,实参,值传递参数,引用传递参数,输出参数,参数数组的学习
查看>>
在Salesforce中创建Approval Process
查看>>