java 对称加密——直接代码中加密

来源:互联网 发布:程序员包装简历公司 编辑:程序博客网 时间:2024/05/16 00:35

 

java中的安全简单点的来说就是关于数据的加密与解密的编程,数据的加密在程序中占据着很重要的一部分,特别是在扯到钱的方面时显得更重要。 数据的加密分为分为两大类即对称加密与非对称加密。

对称加密称为密钥加密,特点速度快,但加密和解密的钥匙必须相同,只有通信双方才能知道钥匙
非对称加密称为公钥加密,特点速度慢,加密和解密的钥匙不相同,某一个人持有私钥,任何人都可以知道公钥

接下来来做一个很简单的关于对称加密的例子,即对一串字符串进行加密然后打印出加密的数据,然后在对其解密输出。

 

package com.cipher.test;import java.security.InvalidKeyException;import java.security.NoSuchAlgorithmException;import javax.crypto.BadPaddingException;import javax.crypto.Cipher;import javax.crypto.IllegalBlockSizeException;import javax.crypto.KeyGenerator;import javax.crypto.NoSuchPaddingException;import javax.crypto.SecretKey;/** *  * @ClassName: SimpleTest1 * @Description: 简单的对称加密(一) * @author 我夕 * @date 2012-5-15 */public class SimpleTest1 {/** * @param args * @throws BadPaddingException  * @throws IllegalBlockSizeException  * @throws NoSuchPaddingException  * @throws NoSuchAlgorithmException  * @throws InvalidKeyException  */public static void main(String[] args) throws InvalidKeyException, NoSuchAlgorithmException, NoSuchPaddingException, IllegalBlockSizeException, BadPaddingException {// TODO Auto-generated method stubsimplCipherTest();}//简单密钥加密public static void simplCipherTest() throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException{//创建Cipher的实例,AES是一个转换名称//有关标准转换名称的信息,请参见 Java Cryptography Architecture Reference Guide 的附录 A。Cipher cipher = Cipher.getInstance("AES");//产生keySecretKey key=KeyGenerator.getInstance("AES").generateKey();//初始化cipher,参数1是Cipher 的操作模式(ENCRYPT_MODE、DECRYPT_MODE、WRAP_MODE 或 UNWRAP_MODE),这里选加密模式//ENCRYPT_MODE,参数二是密钥keycipher.init(Cipher.ENCRYPT_MODE, key);//开始加密数据的操作cipher.update("hello java !".getBytes());byte[] result=cipher.doFinal();//这里返回结果打印出来,便于调试System.out.println("数据加密的结果:"+new String(result));//这里进行解密操作cipher.init(Cipher.DECRYPT_MODE, key);System.out.println("数据解密的结果:"+new String(cipher.doFinal(result)));}}


运行结果:

从运行结果可以看出,得到我们想要的结果了,hello java被加密后就是一堆乱码,根本看不出什么东西出来,只有进行解密后才能看到其原始真正的内容。