android AES对称加密算法使用实例
来源:互联网 发布:ubuntu 网络设置 编辑:程序博客网 时间:2024/06/05 07:12
代码是最好的注释!
public class AES {
public static String mSeed = "leichxxxxx;/* public static String encrypt(String seed, String cleartext)
throws Exception {
byte[] rawKey = getRawKey(seed.getBytes());
byte[] result = encrypt(rawKey, cleartext.getBytes());
return toHex(result);
}
public static String decrypt(String seed, String encrypted)
throws Exception {
byte[] rawKey = getRawKey(seed.getBytes());
byte[] enc = toByte(encrypted);
byte[] result = decrypt(rawKey, enc);
return new String(result);
}*/
public static byte[] encryptExt(String seed, byte[] cleartext)
throws Exception {
byte[] rawKey = getRawKey(seed.getBytes());
byte[] result = encrypt(rawKey, cleartext);
return result;
}
public static byte[] decryptExt(String seed, byte[] encrypted)
throws Exception {
byte[] rawKey = getRawKey(seed.getBytes());
byte[] enc = encrypted;
byte[] result = decrypt(rawKey, enc);
return result;
}
private static byte[] getRawKey(byte[] seed) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG", "Crypto");
sr.setSeed(seed);
kgen.init(128, sr); // 192 and 256 bits may not be available
SecretKey skey = kgen.generateKey();
byte[] raw = skey.getEncoded();
return raw;
}
private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec, new IvParameterSpec(
new byte[cipher.getBlockSize()]));
byte[] encrypted = cipher.doFinal(clear);
return encrypted;
}
private static byte[] decrypt(byte[] raw, byte[] encrypted)
throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES");
cipher.init(Cipher.DECRYPT_MODE, skeySpec, new IvParameterSpec(
new byte[cipher.getBlockSize()]));
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
}
private static byte[] toByte(String hexString) {
int len = hexString.length() / 2;
byte[] result = new byte[len];
for (int i = 0; i < len; i++)
result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2),
16).byteValue();
return result;
}
private static String toHex(byte[] buf) {
if (buf == null)
return "";
StringBuffer result = new StringBuffer(2 * buf.length);
for (int i = 0; i < buf.length; i++) {
appendHex(result, buf[i]);
}
return result.toString();
}
private final static String HEX = "0123456789ABCDEF";
private static void appendHex(StringBuffer sb, byte b) {
sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f));
}
public static void Test() {
String source = "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqrstuvwxyz";
try {
Log.d(CONST.TAG, "source:" + source);
byte[] output = encryptExt(mSeed, source.getBytes());
Log.d(CONST.TAG, "output:" + output);
byte[] output2 = decryptExt(mSeed, output);
Log.d(CONST.TAG, "output2:" + output2);
} catch (Exception e) {
e.printStackTrace();
}
}
}
阅读全文
0 0
- android AES对称加密算法使用实例
- AES 对称加密算法 加密\解密实例
- Android加密算法之对称加密AES
- AES对称加密算法原理
- AES对称加密算法原理
- AES对称加密算法原理
- AES对称加密算法原理
- Security > 对称加密算法AES
- 对称加密算法(AES)
- AES 对称加密算法
- AES对称加密算法
- 对称加密算法AES
- AES对称加密算法扫盲
- 对称加密算法(3):AES
- JAVA-对称加密算法AES
- Android 中对称加密算法DES,DESede,AES的加密和解密 的工具类的使用
- Java 加密 AES 对称加密算法
- 对称加密算法DES、AES、PBE
- 购物车二级列表的实现,在一级列表基础上,bean类里再添加两个字段(请求本地json数据)
- 泛型方法
- eclipse转AS方法2——新目录结构
- 操作符简单剖析
- (十)、Java复习笔记之多线程(1)
- android AES对称加密算法使用实例
- HDU
- SpringBoot--Profile
- spring boot 项目三种启动方式
- 电路实验
- 控制C#中textbox输入文本的格式
- 从零开始学习c++之初识指针和引用
- Java线程学习笔记(一)
- 2017/11/20