文件加密解密二

在加解密操作时,密文总是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);
}
}

你可能感兴趣的:(算法,Security)