在过去的几天里,我一直在努力将Java代码迁移到Golang,现在我陷入困境.这是可用的Java代码:
final Key k = new SecretKeySpec(keyString.getBytes(), "AES");
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.DECRYPT_MODE, k);
final InputStream in = new BufferedInputStream(new FileInputStream(fileNameToDecrypt));
final CipherInputStream instream = new CipherInputStream(in, c);
if (instream.read() != 'B') {
System.out.println("Error");
}
if (instream.read() != 'Z') {
System.out.println("Error");
}
final CBZip2InputStream zip = new CBZip2InputStream(instream);
Run Code Online (Sandbox Code Playgroud)
我在Golang中的实现:
c, _ := aes.NewCipher([]byte(keyString))
// IV must be defined in golang
iv := []byte{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
d := cipher.NewCBCDecrypter(c, iv)
fi, _ := os.Open(fileNameToDecrypt)
stat, _ := fi.Stat()
enc := make([]byte, stat.Size())
dec := make([]byte, stat.Size())
fi.Read(enc)
d.CryptBlocks(dec, enc)
instream := bytes.NewBuffer(dec)
zip := bzip2.NewReader(instream)
Run Code Online (Sandbox Code Playgroud)
到目前为止我所知道的:
_都nil在这段代码中CBzip2InputStream,但不能省略bzip2.NewReaderinstreamJava和golang 读取的前16个字节是相同的,从第17个字节开始,所有字节因任何原因而不同CBizp2InputStream确实使用AES ECB.这是一个有效的实施.我省略了错误处理以缩短代码:
c, _ := aes.NewCipher([]byte(keyString))
bufIn := make([]byte, 16)
bufOut := make([]byte, 16)
dec := bytes.NewBuffer(make([]byte, 0))
var i int
for {
i, _ = src.Read(bufIn)
if i == 0 {
break
}
c.Decrypt(bufOut, bufIn)
dec.Write(bufOut)
}
zip := bzip2.NewReader(dec)
io.Copy(dst, zip)
Run Code Online (Sandbox Code Playgroud)
补充说明:
i == 0用作破坏条件,因为err在上次成功读取时可以或不能设置为io.EOF(参见golang io.Reader规范)完美的工作.现在应该很容易实现加密.
| 归档时间: |
|
| 查看次数: |
1643 次 |
| 最近记录: |