Android中如何使用AES进行加密和解密
作为初入社会的IT行业的大专实习生,只能在公司里被当牛一样每天工作到半夜十二点以后,在这里也是第一次写博客,目的只有两个:1.记录技术实现,尽可能的帮助网友解决困难、2.吐槽公司!
不多说了 直接看代码,在这里我就不说AES加密的原理了,直接看在Android里怎么使用
一.定义常量设置密钥和向量iv的值,在调用方法的时候直接赋值也可以
* 加密用的Key 可以用26个字母和数字组成
* 此处使用AES-128-CBC加密模式,key需要为16位。
*/
private static String sKey="ef8373c04bfd11ea";
private static String ivParameter="0102030405060708";
二.写加密的方法
// 加密
public String encrypt(String sSrc, String encodingFormat, String sKey, String ivParameter) throws Exception {
Cipher cipher = ("AES//CBC/PKCS5Padding");
byte[] raw = ();
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
IvParameterSpec iv = new IvParameterSpec(());//使用CBC模式,需要一个向量iv,可增加加密算法的强度
(Cipher.ENCRYPT_MODE, skeySpec, iv);
byte[] encrypted = ((encodingFormat));
return new BASE64Encoder().encode(encrypted);//此处使用BASE64做转码。
}
二.写解密的方法
// 解密
public String decrypt(String sSrc, String encodingFormat, String sKey, String ivParameter) throws Exception {
try {
byte[] raw = ("ASCII");
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = ("AES/CBC/PKCS5Padding");
IvParameterSpec iv = new IvParameterSpec(());
(Cipher.DECRYPT_MODE, skeySpec, iv);
byte[] encrypted1 = new BASE64Decoder().decodeBuffer(sSrc);//先用base64解密
byte[] original = (encrypted1);
String originalString = new String(original,encodingFormat);
return originalString;
} catch (Exception ex) {
return null;
}
}
三.直接在onCreate里直接调用即可
//参数1:要加密的字符串、参数2:编码格式、参数3:密钥、参数4:向量iv
// 加密
String number = encrypt("123456", "utf-8", "ef8373c04bfd11ea", "0102030405060708");
("number","加密后的123456:"+number);
// 解密
String Denumber = decrypt(number ,"utf-8",sKey,ivParameter);
("number","解密后的123456:"+Denumber );
好了 简单不能再简单的AES加密搞定了,但是我却用了半天的时间才搞定,那边公司还催的要死,“这么简单的AES加密都不会”、“哎呦,你怎么回事,还没搞好”让我很想爆粗口,我也是百度了很久,结合了很多博客的写法。
有问题可以直接加我QQ交流:592693957
谢谢大家!!!
第一次写博客,还望各大网友轻点喷,我心态不好,会跳楼的