java生成和读取keystore_java 读取使用keytool生产的keystore文件

windows 环境下,使用keytool 生产keystore文件

keytool -genkeypair -keyalg RSA -keysize 1024 -sigalg SHA1withRSA -validity 36000 -alias www.kunlunsoft.com -storepass abcdefg -keystore zlex.keystore -dname "CN=localhost, OU=zlex,O=zlex, L=BJ, ST=BJ, C=CN"

说明:-keyalg:指定key的加密算法;

-sigalg:指定签名算法;

-storepass:指定key的密码

注意:keystore密码和主密码必须相同

操作结果如下:

0818b9ca8b590ca3270a3433284dd417.png

上述命令会生产一个文件zlex.keystore

keystore文件中既包含公钥,也包含私钥。

使用java 读取zlex.keystore 文件:

用于保存私钥和公钥的bean:

package com.common.bean;

import java.io.Serializable;

import java.security.PrivateKey;

import java.security.PublicKey;

/***

*

* @author huangwei

* @since 2013-10-28

*/

public class PrivPubKeyBean implements Serializable {

private static final long serialVersionUID = 1888415926054715509L;

/***

* 私钥

*/

private PrivateKey privKey;

/***

* 公钥

*/

private PublicKey publKey;

/***

* 签名算法

*/

private String sigAlgName;

public PrivateKey getPrivKey() {

return privKey;

}

public void setPrivKey(PrivateKey privKey) {

this.privKey = privKey;

}

public PublicKey getPublKey() {

return publKey;

}

public void setPublKey(PublicKey publKey) {

this.publKey = publKey;

}

public String getSigAlgName() {

return sigAlgName;

}

public void setSigAlgName(String sigAlgName) {

this.sigAlgName = sigAlgName;

}

}

读取keystore文件获取私钥和公钥:

/***

*

* @param keyStorePath

* @param password

* @param alias

* @return

* @throws Exception

*/

public static PrivPubKeyBean getPrivPubKeyBean(String keyStorePath,String password,String alias) throws Exception{

PrivPubKeyBean privPubKeyBean=new PrivPubKeyBean();

// 获得密钥库

KeyStore ks =SystemUtil. getKeyStore(keyStorePath, password);

// 获得私钥

PrivateKey privateKey = (PrivateKey) ks.getKey(alias, password.toCharArray());

privPubKeyBean.setPrivKey(privateKey);

// 获得证书

X509Certificate x509Certificate = (X509Certificate) ks.getCertificate(alias);

PublicKey pubKey=x509Certificate.getPublicKey();

privPubKeyBean.setPublKey(pubKey);

privPubKeyBean.setSigAlgName(x509Certificate.getSigAlgName());

return privPubKeyBean;

}

测试:

@Test

public void test_03() {

try {

String message = "whuang";

String keyStorePath = "d:\\Temp\\a\\a\\ca\\zlex.keystore";

String password = "abcdefg";

String alias = "www.kunlunsoft.com";

PrivPubKeyBean privPubKeyBean = SystemUtil.getPrivPubKeyBean(

keyStorePath, password, alias);

byte[] result = SystemUtil.encrypt(message,

privPubKeyBean.getPublKey());

byte[] deResult = SystemUtil.decrypt(result,

privPubKeyBean.getPrivKey());

System.out.println(new String(deResult));

} catch (Exception e) {

e.printStackTrace();

}

}

运行结果:whuang

SystemUtil 见附件,路径:src\main\java\com\common\util\SystemUtil.java

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值