首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2SE开发 >

关于资料的AES加密的难题

2013-06-25 
关于文件的AES加密的难题下边是一个字符串的AES加密,谁能把他扩展成为可以为文件或文件流的加密?package F

关于文件的AES加密的难题
下边是一个字符串的AES加密,谁能把他扩展成为可以为文件或文件流的加密?


package Fastmule.Android;

import java.security.SecureRandom;    

import javax.crypto.Cipher;    
import javax.crypto.KeyGenerator;    
import javax.crypto.SecretKey;    
import javax.crypto.spec.SecretKeySpec;    
/*
加密 – 
1.String encryptingCode = SimpleCrypto.encrypt(masterPassword,originalText);


解密 – 
1.String originalText = SimpleCrypto.decrypt(masterpassword, encryptingCode);
  
 */
   
public class AES_String {    
   
    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 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("AES");    
        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, "AES");    
        Cipher cipher = Cipher.getInstance("AES");    
        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, "AES");    
        Cipher cipher = Cipher.getInstance("AES");    
        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 final static String HEX = "0123456789ABCDEF";    
    private static void appendHex(StringBuffer sb, byte b) {    


        sb.append(HEX.charAt((b>>4)&0x0f)).append(HEX.charAt(b&0x0f));    
    }    
        
}


[解决办法]
朋友给你一个java文件加密的例子,安装这样改吧,举一反三。


 import java.io.ByteArrayInputStream;
  import java.io.ByteArrayOutputStream;
  import java.io.File;
  import java.io.FileInputStream;
  import java.io.FileOutputStream;
  import java.io.InputStream;
  import java.io.ObjectInputStream;
  import java.io.ObjectOutputStream;
  import java.security.Key;
  import java.security.NoSuchAlgorithmException;
  import java.security.SecureRandom;
  import java.security.Security;
  import javax.crypto.Cipher;
  import javax.crypto.KeyGenerator;
  public class DESEncryptUtil {
  public static Key createKey() throws NoSuchAlgorithmException {//创建密钥
  Security.insertProviderAt(new com.sun.crypto.provider.SunJCE(), 1);
  KeyGenerator generator = KeyGenerator.getInstance("DES");
  generator.init(new SecureRandom());
  Key key = generator.generateKey();
  return key;
  }
  public static Key getKey(InputStream is) {
  try {
  ObjectInputStream ois = new ObjectInputStream(is);
  return (Key) ois.readObject();
  } catch (Exception e) {
  e.printStackTrace();
  throw new RuntimeException(e);
  }
  }
  private static byte[] doEncrypt(Key key, byte[] data) {//对数据进行加密?
  try {
  Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
  cipher.init(Cipher.ENCRYPT_MODE, key);
  byte[] raw = cipher.doFinal(data);
  return raw;
  } catch (Exception e) {
  e.printStackTrace();
  throw new RuntimeException(e);
  }
  }
  public static InputStream doDecrypt(Key key, InputStream in) {//对数据进行解密?
  try {
  Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
  cipher.init(Cipher.DECRYPT_MODE, key);
  ByteArrayOutputStream bout = new ByteArrayOutputStream();
  byte[] tmpbuf = new byte[1024];
  int count = 0;
  while ((count = in.read(tmpbuf)) != -1) {
  bout.write(tmpbuf, 0, count);
  tmpbuf = new byte[1024];
  }
  in.close();
  byte[] orgData = bout.toByteArray();


  byte[] raw = cipher.doFinal(orgData);
  ByteArrayInputStream bin = new ByteArrayInputStream(raw);
  return bin;
  } catch (Exception e){
  e.printStackTrace();
  throw new RuntimeException(e);
  }
  }
 public static void main(String[] args) throws Exception{
  System.out.println("===================");
  if (args.length == 2 && args[0].equals("key")){
  Key key = DESEncryptUtil.createKey();
  ObjectOutputStream oos = new ObjectOutputStream(
  new FileOutputStream(args[1]));
  oos.writeObject(key);
  oos.close();
  System.out.println("成功生成密钥文件");
  } else if (args.length == 3 && args[0].equals("encrypt")){
  File file = new File(args[1]);
  FileInputStream in = new FileInputStream(file);
  ByteArrayOutputStream bout = new ByteArrayOutputStream();
  byte[] tmpbuf = new byte[1024];
  int count = 0;
  while ((count = in.read(tmpbuf)) != -1){
  bout.write(tmpbuf, 0, count);
  tmpbuf = new byte[1024];
  }
  in.close();
  byte[] orgData = bout.toByteArray();
  Key key = getKey(new FileInputStream(args[2]));
  byte[] raw = DESEncryptUtil.doEncrypt(key, orgData);
  file = new File(file.getParent() + "\\en_" + file.getName());
  FileOutputStream out = new FileOutputStream(file);
  out.write(raw);
  out.close();
  System.out.println("成功加密,加密文件位:"+file.getAbsolutePath());
  } else if (args.length == 3 && args[0].equals("decrypt")){//对文件进行解密
  File file = new File(args[1]);
  FileInputStream fis = new FileInputStream(file);
  Key key = getKey(new FileInputStream(args[2]));
  InputStream raw = DESEncryptUtil.doDecrypt(key, fis);
  ByteArrayOutputStream bout = new ByteArrayOutputStream();
  byte[] tmpbuf = new byte[1024];
  int count = 0;
  while ((count = raw.read(tmpbuf)) != -1){
  bout.write(tmpbuf, 0, count);
  tmpbuf = new byte[1024];
  }
  raw.close();
  byte[] orgData = bout.toByteArray();
  file = new File(file.getParent() + "\\rs_" + file.getName());
  FileOutputStream fos = new FileOutputStream(file);
  fos.write(orgData);
  System.out.println("成功解密,解密文件位:"+file.getAbsolutePath());
  }else if(args.length==1 && args[0].equals("-h")) {
  System.out.println("\t文件加密解密\n");
  System.out.println





希望对你有帮助

[解决办法]
跨平台操作确实很让人头痛!

热点排行
Bad Request.