des三重加密的问题?(在线等待)
一个解密的函数
一个加密的函数如下:
private byte[] encryptByDES(byte[] bytP,byte[] bytKey) throws Exception{
DESKeySpec desKS = new DESKeySpec(bytKey);
SecretKeyFactory skf = SecretKeyFactory.getInstance("DES");
SecretKey sk = skf.generateSecret(desKS);
Cipher cip = Cipher.getInstance("DES");
cip.init(Cipher.ENCRYPT_MODE,sk);
return cip.doFinal(bytP);
}
我定义了一个buffer,bytIn[10240],对它里边的数据进行加密:
byte[] bytOut = encryptByDES(encryptByDES(encryptByDES(bytIn,bytK1),bytK2),bytK3);
为什么返回的数组 bytOut[] 比以前多了24个,他的长度是10264?
我是想从一个文件每读取一块儿就加密一块儿,然后再向另一个文件里写入一块儿,可是将每一块加密之后都多了24个字节,往加密后的文件写入的时候,是应该写入10264里的哪一部分?最后解密的时候还是用这个函数知识三个密钥的顺序得颠倒,这样做是否正确?
如果还有高招儿,请各位大虾指教
先谢谢给为大虾........