关于des文件的加密,解密。

做断网情况下的设备激活,选择了将数据放在机器分区下面,但是文件比较隐私,不能让别人看到内容,于是用了加密文件,然后在进行系统打包。结果选择了des加密方式,加密后的文件也可以解密,不过后来检查出问题,当加密后,把文件发给我的另一个设备发现不能进行解密,原因是key不一致,原来每次的key都不一样,后来只能指定key值了。这样问题解决了



public class Locker {
 Key key; 
 public Locker(String str) { 
  // getKey(str);//生成密匙 ,该方法每次的key不一致
  //生成密匙 ,该方法指定了生成key值javax.crypto.spec.SecretKeySpec@30
  byte[] bys = new byte[] { 7, 16, -15, -3, 4, -42, 14, 64};
       this.key = new SecretKeySpec(bys, "DES");
 } 
 /** 
 * 根据参数生成KEY 
 */ 
 public void getKey(String strKey) { 
   try { 
       KeyGenerator _generator = KeyGenerator.getInstance("DES"); 
       _generator.init(new SecureRandom(strKey.getBytes())); 
       this.key = _generator.generateKey(); 
      // byte[] bys = key.getEncoded();
       _generator = null; 
   } catch (Exception e) { 
       throw new RuntimeException("Error initializing SqlMap class. Cause: " + e); 
   } 
 } 


 /** 
 * 文件file进行加密并保存目标文件destFile中 
 * 
 * @param file   要加密的文件 如mnt/sdcard/PateokeyNormal.txt 
 * @param destFile 加密后存放的文件名 如mnt/sdcard/Pateokey.txt 
 */ 
 public void encrypt(String file, String destFile) throws Exception { 
   Cipher cipher = Cipher.getInstance("DES"); 
   // cipher.init(Cipher.ENCRYPT_MODE, getKey()); 
   cipher.init(Cipher.ENCRYPT_MODE, this.key); 
   InputStream is = new FileInputStream(file); 
   OutputStream out = new FileOutputStream(destFile); 
   CipherInputStream cis = new CipherInputStream(is, cipher); 
   byte[] buffer = new byte[1024]; 
   int r; 
   while ((r = cis.read(buffer)) > 0) { 
       out.write(buffer, 0, r); 
   } 
   System.out.println("KEY加密="+key);
   cis.close(); 
   is.close(); 
   out.close(); 
 } 
 /** 
 * 文件采用DES算法解密文件 
 * 
 * @param file 已加密的文件 如auth/Pateokey.txt 
 *  
 */ 
 public String decrypt(String file) throws Exception {
 System.out.println("KEY解密="+key);
   Cipher cipher = Cipher.getInstance("DES"); 
   cipher.init(Cipher.DECRYPT_MODE, this.key); 
   
   InputStream is = new FileInputStream(file); 
   String PateoMessage = "";
OutputStream out =System.out; 

//  start
ByteArrayOutputStream baos = new ByteArrayOutputStream();  
 CipherOutputStream cos = new CipherOutputStream(baos, cipher); 
//  end
//    CipherOutputStream cos = new CipherOutputStream(out, cipher); 
  
 
   byte[] buffer = new byte[1024]; 
   int r; 
   while ((r = is.read(buffer)) >= 0) {
    cos.write(buffer, 0, r);       
   } 
    
   cos.close(); 
   //out.close(); 
   is.close();
   PateoMessage=baos.toString();
   baos.close();
return PateoMessage;
 } 

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值