我想使用 AES-256 在 Go 中加密字符串,无需任何 GCM 处理,以与 MQL4 进行比较。当我尝试加密特殊字符或数字时遇到问题。我应该以某种方式预处理我的明文吗?我是Go的新手,所以任何帮助将不胜感激;我的代码在这个解释下面。
如果我加密明文“这是一个秘密”,然后解密密文(编码为十六进制),我得到相同的结果(即“这是一个秘密”)。pt 是以下代码中明文的变量名称。
如果我试图加密“这是一个秘密;1234“,密文末尾有一组零,当我解密时,我只得到”这是一个秘密”。MQL4 中的类似密文末尾没有零,并且可以正确解密。
如果我尝试仅加密“1234”,则会出现构建错误,源于“crypto/aes.(*aesCipherAsm).Encrypt(0xc0000c43c0, 0xc0000ac058, 0x4, 0x4, 0xc0000ac070, 0x4, 0x8) C:/Program Files/Go/src/crypto/aes/cipher_asm.go:60 +0x125”
这是我的代码:
package main
import (
"crypto/aes"
"encoding/hex"
"fmt"
)
func main() {
// cipher key
key := "thisis32bitlongpassphraseimusing"
// plaintext
pt := "This is a secret"
// pt := "This is a secret; 1234" // zeroes in ciphertext
// pt := "1234" // doesn't build
c := EncryptAES([]byte(key), pt)
// plaintext
fmt.Println(pt)
// ciphertext
fmt.Println(c)
// decrypt
DecryptAES([]byte(key), c)
}
func EncryptAES(key []byte, plaintext string) string {
c, err := aes.NewCipher(key)
CheckError(err)
out := make([]byte, len(plaintext))
c.Encrypt(out, []byte(plaintext))
return hex.EncodeToString(out)
}
func DecryptAES(key []byte, ct string) {
ciphertext, _ := hex.DecodeString(ct)
c, err := aes.NewCipher(key)
CheckError(err)
pt := make([]byte, len(ciphertext))
c.Decrypt(pt, ciphertext)
s := string(pt[:])
fmt.Println("DECRYPTED:", s)
}
func CheckError(err error) {
if err != nil {
panic(err)
}
}
开满天机
沧海一幻觉
相关分类