获取Android签名证书的公钥和私钥的简单实例

作者:jingxian 时间:2022-10-02 22:20:13 

本文以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;

}

}
标签:公钥,私钥,签名,android
0
投稿

猜你喜欢

  • Java泛型的简单实例

    2023-11-27 01:03:38
  • c# 使用线程对串口serialPort进行收发数据(四种)

    2023-06-20 13:05:48
  • SpringCloud feign服务熔断下的异常处理操作

    2022-01-11 20:22:45
  • Android自定义View原理(实战)

    2021-07-25 02:46:47
  • 将15位身份证补全为18位身份证的算法示例详解

    2022-07-15 19:33:43
  • Android长按imageview把图片保存到本地的实例代码

    2021-07-23 14:20:38
  • java 读取系统Properties代码实例

    2023-02-22 04:21:52
  • Java编程实现轨迹压缩算法开放窗口实例代码

    2021-12-03 09:54:07
  • SpringBoot瘦身打包部署的实现

    2021-09-09 16:54:21
  • SSM项目使用拦截器实现登录验证功能

    2023-06-17 16:12:38
  • Java NIO实现多人聊天室

    2022-04-05 09:03:17
  • Android实现ViewPager无限循环效果(一)

    2022-08-02 18:58:34
  • cmd中javac和java使用及注意事项详解

    2022-03-25 10:37:36
  • SpringBoot整合SpringTask实现定时任务的流程

    2022-03-28 22:24:40
  • Android ContentProvider实现获取手机联系人功能

    2023-08-07 00:52:27
  • java操作elasticsearch的案例解析

    2021-06-27 19:17:13
  • Java中synchronized关键字修饰方法同步的用法详解

    2022-03-05 07:11:22
  • IDEA简单实现登录注册页面

    2023-08-06 19:10:37
  • C#中缓存System.Web.Caching用法总结

    2021-09-05 04:41:11
  • 浅析Java中的异常处理机制

    2021-08-19 05:42:48
  • asp之家 软件编程 m.aspxhome.com