码迷,mamicode.com
首页 > 编程语言 > 详细

java

时间:2017-10-19 12:41:29      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:加解密

public class AESUtils {
    public static final String AES_GIV   = "ASwsqwerty1uDs";//定义16为偏移向量
    public static Log          logger    = LogFactory.getLog(AESUtils.class);
    /**
     * 加密
     * @param String sSrc需要加密的参数
     * @param String sKey密钥16位长度的String
     * @return String 加密后的数据
     */
    public static String Encrypt(String sSrc, String sKey) throws Exception {
        if (sKey == null) {
            logger.warn("Key为空null");
            return null;
        }
        // 判断Key是否为16位
        if (sKey.length() != 16) {
            logger.warn("Key长度不是16位");
            return null;
        }
        byte[] raw = sKey.getBytes();
        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");// "算法/模式/补码方式"
        IvParameterSpec iv = new IvParameterSpec(AES_GIV.getBytes());// 使用CBC模式,需要一个向量iv,可增加加密算法的强度
        cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
        byte[] encrypted = cipher.doFinal(sSrc.getBytes());
        return new BASE64Encoder().encode(encrypted);// 此处使用BASE64做转码功能,同时能起到2次加密的作用。
    }
    /**
     * 解密
     * @param String sSrc需要解密的参数
     * @param String sKey密钥16位长度的String
     * @return String 解密后的数据
     */
    public static String Decrypt(String sSrc, String sKey) throws Exception {
        try {
            // 判断Key是否正确
            if (sKey == null) {
                logger.warn("Key为空null");
                return null;
            }
            // 判断Key是否为16位
            if (sKey.length() != 16) {
                logger.warn("Key长度不是16位");
                return null;
            }
            byte[] raw = sKey.getBytes("ASCII");
            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
            IvParameterSpec iv = new IvParameterSpec(AES_GIV.getBytes());
            cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);
            byte[] encrypted1 = new BASE64Decoder().decodeBuffer(sSrc);// 先用base64解密
            try {
                byte[] original = cipher.doFinal(encrypted1);
                String originalString = new String(original);
                return originalString;
            } catch (Exception e) {
                logger.error("Decrypt error", e);
                return null;
            }
        } catch (Exception e) {
            logger.error("Decrypt error", e);
            return null;
        }
    }

--------------------------测试--------------------

测试时传密钥和需要加解密的参数

本文出自 “13174837” 博客,请务必保留此出处http://13184837.blog.51cto.com/13174837/1974113

java

标签:加解密

原文地址:http://13184837.blog.51cto.com/13174837/1974113

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!