在加解密操作时,密文总是8的倍数,比如明文有51个字节,加密后就会有56个字节,des会自动加上其它字符(空格)来补上,所以加密解密前内容可能有些不一样,需要注意.
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class DES1 {
private final static String KEY="111111111";//字节数必须是8的整数倍
/**
* 加密
* @param src 要加密的字符串
* @return
* @throws Exception
*/
public static String encrypt(String src) throws Exception{
//DES算法要求有一个可信任的随机数源
SecureRandom sr=new SecureRandom();
//创建一个 DESKeySpec 对象,指定一个 DES 密钥
DESKeySpec ks=new DESKeySpec(KEY.getBytes());
//生成指定秘密密钥算法的 SecretKeyFactory 对象。
SecretKeyFactory skf=SecretKeyFactory.getInstance("DES");
//利用密钥工厂把DESKeySpec转换成一个SecretKey对象
SecretKey sk=skf.generateSecret(ks);
//Cipher对象实际完成加解密操作
Cipher cip=Cipher.getInstance("DES");
//用密钥和随机源初始化此 cipher
cip.init(Cipher.ENCRYPT_MODE, sk,sr);
//doFinal 按单部分操作加密或解密数据,在调用byteToHex 转换为16进制字符串
String dest=byteToHex(cip.doFinal(src.getBytes()));
return dest;
}
/**
* 解密
* @param src
* @return
* @throws Exception
*/
public static String decrypt(String src)throws Exception{
SecureRandom sr=new SecureRandom();
DESKeySpec ks=new DESKeySpec(KEY.getBytes());
SecretKeyFactory skf=SecretKeyFactory.getInstance("DES");
SecretKey sk=skf.generateSecret(ks);
Cipher cip=Cipher.getInstance("DES");
//下面和上面的加密就不同了
cip.init(Cipher.DECRYPT_MODE, sk,sr);
//先将16进制字符串转换为字节数组,在调用doFinal解密
String dest=new String(cip.doFinal(hexToByte(src)));
return dest;
}
//字节数组转换为16进制字符串
public static String byteToHex(byte[] bs){
String str="";
for(int i=0;i<bs.length;i++){
String s=Integer.toHexString(bs[i]);
int len=s.length();
if(len==1){ //长度只有一位在前面补0
s="0"+s;
}else{ //长度大于2位是因为Integer是16位的,所以截取后2位
s=s.substring(len-2);
}
str+=s;
}
return str;
}
//为16进制字符串转换字节数组
private static byte[] hexToByte(String hex){
byte[] srcBs=hex.getBytes();
byte[] desBs=new byte[srcBs.length/2];
for(int i=0;i<srcBs.length;i+=2){
byte b=(byte)Integer.parseInt(new String(srcBs,i,2),16);
desBs[i/2]=b;
}
return desBs;
}
public static void main(String[] args) throws Exception{
//加密
String des=encrypt("my name is 有小平");
System.out.println(des);
//解密
String decrypt=decrypt(des);
System.out.println(decrypt);
}
}
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class DES1 {
private final static String KEY="111111111";//字节数必须是8的整数倍
/**
* 加密
* @param src 要加密的字符串
* @return
* @throws Exception
*/
public static String encrypt(String src) throws Exception{
//DES算法要求有一个可信任的随机数源
SecureRandom sr=new SecureRandom();
//创建一个 DESKeySpec 对象,指定一个 DES 密钥
DESKeySpec ks=new DESKeySpec(KEY.getBytes());
//生成指定秘密密钥算法的 SecretKeyFactory 对象。
SecretKeyFactory skf=SecretKeyFactory.getInstance("DES");
//利用密钥工厂把DESKeySpec转换成一个SecretKey对象
SecretKey sk=skf.generateSecret(ks);
//Cipher对象实际完成加解密操作
Cipher cip=Cipher.getInstance("DES");
//用密钥和随机源初始化此 cipher
cip.init(Cipher.ENCRYPT_MODE, sk,sr);
//doFinal 按单部分操作加密或解密数据,在调用byteToHex 转换为16进制字符串
String dest=byteToHex(cip.doFinal(src.getBytes()));
return dest;
}
/**
* 解密
* @param src
* @return
* @throws Exception
*/
public static String decrypt(String src)throws Exception{
SecureRandom sr=new SecureRandom();
DESKeySpec ks=new DESKeySpec(KEY.getBytes());
SecretKeyFactory skf=SecretKeyFactory.getInstance("DES");
SecretKey sk=skf.generateSecret(ks);
Cipher cip=Cipher.getInstance("DES");
//下面和上面的加密就不同了
cip.init(Cipher.DECRYPT_MODE, sk,sr);
//先将16进制字符串转换为字节数组,在调用doFinal解密
String dest=new String(cip.doFinal(hexToByte(src)));
return dest;
}
//字节数组转换为16进制字符串
public static String byteToHex(byte[] bs){
String str="";
for(int i=0;i<bs.length;i++){
String s=Integer.toHexString(bs[i]);
int len=s.length();
if(len==1){ //长度只有一位在前面补0
s="0"+s;
}else{ //长度大于2位是因为Integer是16位的,所以截取后2位
s=s.substring(len-2);
}
str+=s;
}
return str;
}
//为16进制字符串转换字节数组
private static byte[] hexToByte(String hex){
byte[] srcBs=hex.getBytes();
byte[] desBs=new byte[srcBs.length/2];
for(int i=0;i<srcBs.length;i+=2){
byte b=(byte)Integer.parseInt(new String(srcBs,i,2),16);
desBs[i/2]=b;
}
return desBs;
}
public static void main(String[] args) throws Exception{
//加密
String des=encrypt("my name is 有小平");
System.out.println(des);
//解密
String decrypt=decrypt(des);
System.out.println(decrypt);
}
}