Java security KeyStore Cipher

本文通过一个具体的示例展示了如何使用Java密钥工具(keytool)生成密钥对,并进行加密与解密操作。首先介绍了如何生成带有密码保护的密钥库文件,接着演示了如何加载该密钥库并获取其中的证书。最后,利用获得的公钥和私钥完成了信息的加密和解密过程。

http://docs.oracle.com/javase/7/docs/technotes/guides/security/crypto/CryptoSpec.html

 

//c:\Program Files\Java\jdk1.7.0_01\bin>keytool.exe -genkeypair -alias alex -keyalg RSA -keysize 1024 -storepass 123456 -v
		
		KeyStore keyStore = KeyStore.getInstance("jks");
		char[] password = "123456".toCharArray();
		keyStore.load(new FileInputStream("c:/users/administrator/.keystore"), password);
		Enumeration<String> aliases = keyStore.aliases();
		while(aliases.hasMoreElements()){
			String element = aliases.nextElement();
			System.out.println(element);
		}
		String alias = "alex";
		Certificate cer = keyStore.getCertificate(alias);
		String s = cer.toString();
		System.out.println(s);
		System.out.println("public key algorithm:"+cer.getPublicKey().getAlgorithm());
		Cipher cipher = Cipher.getInstance(cer.getPublicKey().getAlgorithm());
		cipher.init(Cipher.ENCRYPT_MODE, cer);
		byte[] msg = cipher.doFinal("hello alex".getBytes());
		System.out.println("encrypt result:"+new String(msg));
		
		Key key = keyStore.getKey(alias, password);
		String algorithm = key.getAlgorithm();
		System.out.println("key algorithm:"+algorithm);
		cipher = Cipher.getInstance(algorithm);
		cipher.init(Cipher.DECRYPT_MODE, key);
		byte[] result = cipher.doFinal(msg);
		System.out.println("decrypt result:"+new String(result));

转载于:https://my.oschina.net/fangwei/blog/717253

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值