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

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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值