package com.kuquo.servlet;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.IvParameterSpec;
public class DESModeTest {
// DES加密解密的密钥,必须为8的倍数
private final static String DESKEY = "cailanzi";
public static void main(String[] args) {
try {
String username = "测试DES加密解密";//new String("测试DES加密解密".getBytes("ASCII"),"UTF-8");
System.out.println("等待加密的数据--->>"+username);
// 用户名加密
//username = java.net.URLEncoder.encode(username, "UTF-8");
//System.out.println("\n要加密的数据--->>" + username);
username = new DESModeTest().toHexString(new DESModeTest().encrypt(username));
System.out.println("加密后的数据为--->>" + username);
//username = java.net.URLEncoder.encode(username, "UTF-8"); // 用户名加密
//System.out.println("\n要解密的数据--->>" + username);
username = java.net.URLDecoder.decode(new DESModeTest().decrypt(username), "UTF-8");
System.out.println("解密后的数据--->>" + username);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 加密数据
* @param message 需要加密的字符串
* @return byte[] 加密之后的字节数组
*/
public byte[] encrypt(String message) throws Exception {
// 指定加密类型并初始化
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
// 使用约定好的密钥,初始化
DESKeySpec desKeySpec = new DESKeySpec(DESKEY.getBytes("UTF-8"));
// 获得DES模式的密钥工厂实例
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 获取密钥
SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
// 根据密钥初始化iv
IvParameterSpec iv = new IvParameterSpec(DESKEY.getBytes("UTF-8"));
// 指定ENCRYPT_MODE(加密)模式
cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
// 对数据进行加密并返回
return cipher.doFinal(message.getBytes("UTF-8"));
}
/**
* 解密数据
* @param message 需要解密的数据(此参数应为16进制的字符串)
* @return String 解密之后的字符串
*/
public String decrypt(String message) throws Exception {
// 将16进制的字符串转换为字节数组
byte[] bytesrc = convertHexString(message);
// 指定加密类型并初始化
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
// 使用约定好的密钥,初始化
DESKeySpec desKeySpec = new DESKeySpec(DESKEY.getBytes("UTF-8"));
// 获得DES模式的密钥工厂实例
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 获取密钥
SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
// 根据密钥初始化iv
IvParameterSpec iv = new IvParameterSpec(DESKEY.getBytes("UTF-8"));
// 指定DECRYPT_MODE(解密)模式
cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
// 对转换后的字节数组进行解密
byte[] retByte = cipher.doFinal(bytesrc);
// 使用utf-8编码将解密的后字节数组以字符串的形式返回
return new String(retByte, "UTF-8");
}
// 将16进制的字符串转换为字节数组
public static byte[] convertHexString(String ss) {
byte digest[] = new byte[ss.length() / 2];
for (int i = 0; i < digest.length; i++) {
String byteString = ss.substring(2 * i, 2 * i + 2);
int byteValue = Integer.parseInt(byteString, 16);
digest[i] = (byte) byteValue;
}
return digest;
}
// 将字节数组转换为16进制的字符串
public String toHexString(byte b[]) {
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < b.length; i++) {
String plainText = Integer.toHexString(0xff & b[i]);
if (plainText.length() < 2) {
plainText = "0" + plainText;
}
hexString.append(plainText);
}
return hexString.toString();
}
}
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.IvParameterSpec;
public class DESModeTest {
// DES加密解密的密钥,必须为8的倍数
private final static String DESKEY = "cailanzi";
public static void main(String[] args) {
try {
String username = "测试DES加密解密";//new String("测试DES加密解密".getBytes("ASCII"),"UTF-8");
System.out.println("等待加密的数据--->>"+username);
// 用户名加密
//username = java.net.URLEncoder.encode(username, "UTF-8");
//System.out.println("\n要加密的数据--->>" + username);
username = new DESModeTest().toHexString(new DESModeTest().encrypt(username));
System.out.println("加密后的数据为--->>" + username);
//username = java.net.URLEncoder.encode(username, "UTF-8"); // 用户名加密
//System.out.println("\n要解密的数据--->>" + username);
username = java.net.URLDecoder.decode(new DESModeTest().decrypt(username), "UTF-8");
System.out.println("解密后的数据--->>" + username);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 加密数据
* @param message 需要加密的字符串
* @return byte[] 加密之后的字节数组
*/
public byte[] encrypt(String message) throws Exception {
// 指定加密类型并初始化
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
// 使用约定好的密钥,初始化
DESKeySpec desKeySpec = new DESKeySpec(DESKEY.getBytes("UTF-8"));
// 获得DES模式的密钥工厂实例
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 获取密钥
SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
// 根据密钥初始化iv
IvParameterSpec iv = new IvParameterSpec(DESKEY.getBytes("UTF-8"));
// 指定ENCRYPT_MODE(加密)模式
cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
// 对数据进行加密并返回
return cipher.doFinal(message.getBytes("UTF-8"));
}
/**
* 解密数据
* @param message 需要解密的数据(此参数应为16进制的字符串)
* @return String 解密之后的字符串
*/
public String decrypt(String message) throws Exception {
// 将16进制的字符串转换为字节数组
byte[] bytesrc = convertHexString(message);
// 指定加密类型并初始化
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
// 使用约定好的密钥,初始化
DESKeySpec desKeySpec = new DESKeySpec(DESKEY.getBytes("UTF-8"));
// 获得DES模式的密钥工厂实例
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 获取密钥
SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
// 根据密钥初始化iv
IvParameterSpec iv = new IvParameterSpec(DESKEY.getBytes("UTF-8"));
// 指定DECRYPT_MODE(解密)模式
cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
// 对转换后的字节数组进行解密
byte[] retByte = cipher.doFinal(bytesrc);
// 使用utf-8编码将解密的后字节数组以字符串的形式返回
return new String(retByte, "UTF-8");
}
// 将16进制的字符串转换为字节数组
public static byte[] convertHexString(String ss) {
byte digest[] = new byte[ss.length() / 2];
for (int i = 0; i < digest.length; i++) {
String byteString = ss.substring(2 * i, 2 * i + 2);
int byteValue = Integer.parseInt(byteString, 16);
digest[i] = (byte) byteValue;
}
return digest;
}
// 将字节数组转换为16进制的字符串
public String toHexString(byte b[]) {
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < b.length; i++) {
String plainText = Integer.toHexString(0xff & b[i]);
if (plainText.length() < 2) {
plainText = "0" + plainText;
}
hexString.append(plainText);
}
return hexString.toString();
}
}