android客户端加密代码
2013-02-25 20:22
232 查看
Java代码
package com.devchina.scurity;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
public class SecurityEnDe {
private static
final String defalutSeed = "devchina";
private static
final String algorithm = "AES";
private final
static String HEX = "0123456789ABCDEF";
public static String encrypt(String cleartext)
throws Exception {
return encrypt(defalutSeed, cleartext);
}
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 encrypted)
throws Exception {
return decrypt(defalutSeed, encrypted);
}
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);
}
private static
byte[] getRawKey(byte[] seed)
throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance(algorithm);
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
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, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(clear);
return encrypted;
}
private static
byte[] decrypt(byte[] raw,
byte[] encrypted)
throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
}
public static String toHex(String txt) {
return toHex(txt.getBytes());
}
public static String fromHex(String hex) {
return new String(toByte(hex));
}
public 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;
}
public 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 static
void appendHex(StringBuffer sb, byte b) {
sb.append(HEX.charAt((b >> 4) &
0x0f)).append(HEX.charAt(b & 0x0f));
}
}
package com.devchina.scurity;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
public class SecurityEnDe {
private static
final String defalutSeed = "devchina";
private static
final String algorithm = "AES";
private final
static String HEX = "0123456789ABCDEF";
public static String encrypt(String cleartext)
throws Exception {
return encrypt(defalutSeed, cleartext);
}
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 encrypted)
throws Exception {
return decrypt(defalutSeed, encrypted);
}
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);
}
private static
byte[] getRawKey(byte[] seed)
throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance(algorithm);
SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
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, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(clear);
return encrypted;
}
private static
byte[] decrypt(byte[] raw,
byte[] encrypted)
throws Exception {
SecretKeySpec skeySpec = new SecretKeySpec(raw, algorithm);
Cipher cipher = Cipher.getInstance(algorithm);
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
}
public static String toHex(String txt) {
return toHex(txt.getBytes());
}
public static String fromHex(String hex) {
return new String(toByte(hex));
}
public 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;
}
public 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 static
void appendHex(StringBuffer sb, byte b) {
sb.append(HEX.charAt((b >> 4) &
0x0f)).append(HEX.charAt(b & 0x0f));
}
}
相关文章推荐
- android客户端加密代码
- android客户端与服务器对发信息代码
- Android 热修复补丁管理,后端代码+客户端 sdk
- Android仿人人客户端(v5.7.1)——Auth授权认证(整理流程,重构代码)
- Android客户端和Java服务器端Socket代码连的坑(接空指针异常问题)
- Android 2.0上使用蓝牙通信代码片断(服务端、客户端、数据传输)
- android客户端从服务器端获取json数据并解析的实现代码
- 窥探支付宝钱包android客户端的屏幕加密解锁
- android客户端从服务器端获取json数据并解析的实现代码
- Android C2DM学习——客户端代码开发
- android应用客户端自动升级代码
- Android 代码混淆、第三方平台加固加密、渠道分发 完整教程(图文)
- Android的伪加密解析代码
- apkprotect(免费android代码混淆、加密保护工具) Android中的Apk的加固(加壳)原理解析和实现
- ECClient 红孩子android客户端listview图片加载(优化)核心代码分析
- Android手机客户端通过JSP实现与Tomcat服务器端通信(Msql数据库,Json作为载体)--客户端代码
- Android客户端从服务器端获取json数据并解析的实现代码
- Android:客户端和服务器之间传输数据加密
- AndroidPN服务器与客户端代码分析
- 服务器基于PHP CodeIgniter,Android基于Volley实现多文件/图片上传(含服务器,web版和android客户端完整代码)