下载地址:http://download.csdn.net/detail/a1031359915/9495948

在网上找了很多相关的AES加密方式,遇到的问题有:1、ios与Android调通,而java后台不能使用;2、Android与java调通,ios不能使用


在搜索大片资源后,终于发现了一款适合的,我们都是代码搬运工,(*^__^*) 嘻嘻……


import javax.crypto.Cipher;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecretKeySpec;/** * AES 是一种可逆加密算法,对用户的敏感信息加密处理 对原始数据进行AES加密后,在进行Base64编码转化; */public class AESOperator {    /*     * 加密用的Key 可以用26个字母和数字组成 此处使用AES-128-CBC加密模式,key需要为16位。     */    private String sKey = "7856412346543216";    private String ivParameter = "0392039203920300";    private static AESOperator instance = null;    private AESOperator() {    }    public static AESOperator getInstance() {        if (instance == null)            instance = new AESOperator();        return instance;    }    public static String Encrypt(String encData ,String secretKey,String vector) throws Exception {        if(secretKey == null) {            return null;        }        if(secretKey.length() != 16) {            return null;        }        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");        byte[] raw = secretKey.getBytes();        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");        IvParameterSpec iv = new IvParameterSpec(vector.getBytes());// 使用CBC模式,需要一个向量iv,可增加加密算法的强度        cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);        byte[] encrypted = cipher.doFinal(encData.getBytes("utf-8"));        return Base64.encode(encrypted);// 此处使用BASE64做转码。    }    // 加密    public String encrypt(String sSrc) throws Exception {        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");        byte[] raw = sKey.getBytes();        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");        IvParameterSpec iv = new IvParameterSpec(ivParameter.getBytes());// 使用CBC模式,需要一个向量iv,可增加加密算法的强度        cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);        byte[] encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));        return Base64.encode(encrypted);// 此处使用BASE64做转码。    }    // 解密    public String decrypt(String sSrc) throws Exception {        try {            byte[] raw = sKey.getBytes("ASCII");            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");            IvParameterSpec iv = new IvParameterSpec(ivParameter.getBytes());            cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);            byte[] encrypted1 = Base64.decode(sSrc);// 先用base64解密            byte[] original = cipher.doFinal(encrypted1);            String originalString = new String(original, "utf-8");            return originalString;        } catch (Exception ex) {            return null;        }    }    public String decrypt(String sSrc,String key,String ivs) throws Exception {        try {            byte[] raw = key.getBytes("ASCII");            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");            IvParameterSpec iv = new IvParameterSpec(ivs.getBytes());            cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);            byte[] encrypted1 = Base64.decode(sSrc);// 先用base64解密            byte[] original = cipher.doFinal(encrypted1);            String originalString = new String(original, "utf-8");            return originalString;        } catch (Exception ex) {            return null;        }    }    public static String encodeBytes(byte[] bytes) {        StringBuffer strBuf = new StringBuffer();        for (int i = 0; i < bytes.length; i++) {            strBuf.append((char) (((bytes[i] >> 4) & 0xF) + ((int) 'a')));            strBuf.append((char) (((bytes[i]) & 0xF) + ((int) 'a')));        }        return strBuf.toString();    }    public static void test() {        try {            // 需要加密的字串            String cSrc = "love";            // 加密            long lStart = System.currentTimeMillis();            String enString = AESOperator.getInstance().encrypt(cSrc);            System.out.println("1:" + enString);            long lUseTime = System.currentTimeMillis() - lStart;            System.out.println("2:" + lUseTime + "ms");            // 解密            lStart = System.currentTimeMillis();            String DeString = AESOperator.getInstance().decrypt(enString);            System.out.println("3:" + DeString);            lUseTime = System.currentTimeMillis() - lStart;            System.out.println("4:" + lUseTime + "ms");        } catch (Exception e) {            e.getMessage();        }    }}


更多相关文章

  1. Android的联通性---USB主机模式(一)
  2. Android下的Activity的四种启动模式
  3. Linux(Ubuntu)环境下开启Android真机USB调试模式
  4. usb连接的PTP模式,同时显示内置、外置SD卡内容
  5. Android 启动模式简析
  6. Android : Builder模式 详解及学习使用
  7. 3.NDK Android jni开发 C语言中打印log debug模式下 (相机图片美

随机推荐

  1. jquery validate和jquery form 插件组合
  2. 使用jquery ajax代替iframe
  3. 在没有重新设置源选项的情况下,使用x-edit
  4. 函数的作用是:显示内联块。如何?
  5. 前台jquery+ajax向后台请求数据,后台返回j
  6. 使用js和ajax从django服务器检索数据
  7. 如何删除/更改JQuery UI自动完成帮助文本
  8. jQuery的deferred对象详解
  9. js和jquery使按钮失效为不可用状态的方法
  10. fullcalendar.js - 在按钮点击时删除事