简单的一个java版的AES文件加密demo, 运行正常, 但文件一大速度就会很慢,不知道是否能优化一下,以提高增快加密的速度, 或许是我的代码写法有问题, 希望各位大俠指正      
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.security.SecureRandom;import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;public class AES { // 加密文件
 public static void encryptfile(String pwd, File fileIn) throws Exception {
  try {
            //读取文件
   FileInputStream fis = new FileInputStream(fileIn);
   byte[] bytIn = new byte[(int) fileIn.length()];
   for (int i = 0; i < fileIn.length(); i++) {
    bytIn[i] = (byte) fis.read();
   }
            //AES加密
   KeyGenerator kgen = KeyGenerator.getInstance("AES");
   kgen.init(128, new SecureRandom(pwd.getBytes()));
   SecretKey skey = kgen.generateKey();
   byte[] raw = skey.getEncoded();
   SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
   Cipher cipher = Cipher.getInstance("AES");
   cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
            //写文件
   byte[] bytOut = cipher.doFinal(bytIn);
   FileOutputStream fos = new FileOutputStream(fileIn.getPath()
     + ".aes");
   for (int i = 0; i < bytOut.length; i++) {
    fos.write((int) bytOut[i]);
   }
   fos.close();
   fis.close();
  } catch (Exception e) {
   throw new Exception(e.getMessage());
  }
 }
 public static void main(String[] args) throws Exception {
  AES aes = new AES();
  String pwd = "123";
  File file = new File("d:/xxx.doc");
  aes.encryptfile(pwd, file);
 }
}这是我在别的论坛发现的问题,想发出来请各位大小看看到底怎么回事,还有就是对于加密速度,想请教下怎样才能提高速度?
最后我看他好像是自己手动完成了加密一样,能不能直接用语句crypt(infile,outfile,cipher);来实现加密,我见别人的例子中好像出现过 crypt() 这个方法,但是我在 api 中却查不到他,希望各位大侠能指教下。

解决方案 »

  1.   

    fos.write((int) bytOut[i]);这样效率不高
      

  2.   

    还是没弄明白,到底怎样才算高效?还有就是 crypt() 这个方法大概是这样用的 crypt(filein,fileout,key);我见别人在代码中写过,但是我在 api 中却找不到,很想知道这个方法到底是怎么回事。
      

  3.   

    无非是通过key参与对filein的加密运算以输出fileout,可以把crypt方法看成一个黑盒函数,具体算法就不得而知了
      

  4.   

    慢就在读写上,都是一个字节一个字节的读写 这样肯定很慢,  读写用带buffer的,操作的时候再按字节去操作 这样会快点
      

  5.   


    对于单核CPU来说,你说的没错,但是对于现在主流的多核CPU来说,多线程就起作用了,因为线程会被分配到其他核心去运算。