AES加密

package com.common.uitls;

import java.util.Date;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;

import sun.misc.BASE64Decoder;

/**
 * 换用Apache的 commons-codec.jar, Base64.encodeBase64String(byte[])得到的编码字符串是不带换行符的
 * 根据RFC822规定,BASE64Encoder编码每76个字符,还需要加上一个回车换行 
 * 部分Base64编码的java库还按照这个标准实行
 *
 */




/**
 * 密码加密解密
 * @author wangzhenshun
 *
 */
public class SecurityCodeUtil {
    
	/**
	  * 解密
	  * @param encodeRules
	  * @param content
	  * @return
	  */
	 public static String AESDncode(String encodeRules,String content){
	        try {
	            //1.根据字节数组生成AES密钥
	            SecretKey key=new SecretKeySpec(encodeRules.getBytes(), "AES");
	              //2.根据指定算法AES自成密码器
	            Cipher cipher=Cipher.getInstance("AES");
	              //3.初始化密码器,第一个参数为加密(Encrypt_mode)或者解密(Decrypt_mode)操作,第二个参数为使用的KEY
	            cipher.init(Cipher.DECRYPT_MODE, key);
	            //4.将加密并编码后的内容解码成字节数组
	            byte [] byte_content= new BASE64Decoder().decodeBuffer(content);
	            
	            /*
	             * 解密
	             */
	            byte [] byte_decode=cipher.doFinal(byte_content);
	            String AES_decode=new String(byte_decode,"utf-8");
	            return AES_decode;
	        } catch (Exception e) {
	            e.printStackTrace();
	        } 
	        //如果有错就返加nulll
	        return null;         
	    }
	 
	 /**
	  * 加密
	  * @param encodeRules
	  * @param content
	  * @return
	  */
	 public static String AESEncode(String encodeRules,String content){
	        try {
	               //1.根据字节数组生成AES密钥
	            SecretKey key=new SecretKeySpec(encodeRules.getBytes(), "AES");
	              //2.根据指定算法AES自成密码器
	            Cipher cipher=Cipher.getInstance("AES");
	              //3.初始化密码器,第一个参数为加密(Encrypt_mode)或者解密解密(Decrypt_mode)操作,第二个参数为使用的KEY
	            cipher.init(Cipher.ENCRYPT_MODE, key);
	            //4.获取加密内容的字节数组(这里要设置为utf-8)不然内容中如果有中文和英文混合中文就会解密为乱码
	            byte [] byte_encode=content.getBytes("utf-8");
	            //5.根据密码器的初始化方式--加密:将数据加密
	            byte [] byte_AES=cipher.doFinal(byte_encode);
	            //6.将加密后的数据转换为字符串
	            //这里用Base64Encoder中会找不到包
	            //解决办法: 在项目的Build path中先移除JRE System Library,再添加库JRE System Library,重新编译后就一切正常了。
//	            String AES_encode=new String(new BASE64Encoder().encode(byte_AES));  此方法base64后会换行
	            String AES_encode=Base64.encodeBase64String(byte_AES);  //此方法base64后不会换行
	            //7.将字符串返回
	            return AES_encode;
	        } catch (Exception e) {
	            e.printStackTrace();
	        } 
	        //如果有错就返加nulll
	        return null;         
	    } 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值