登录
首页 >  Golang >  Go问答

无法使用 OpenSSL 解密由 AES 加密的文件

来源:stackoverflow

时间:2024-03-11 14:00:43 115浏览 收藏

怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《无法使用 OpenSSL 解密由 AES 加密的文件》,涉及到,有需要的可以收藏一下

问题内容

我已经使用此代码加密了一个文件。

block, err := aes.NewCipher([]byte("TESTPASSWORD1234TESTPASSWORD1234"))
    if err != nil {
        panic(err)
    }

    bReader, err := os.Open("doc.docx")
    if err != nil {
        panic(err)
    }

    var iv [aes.BlockSize]byte
    stream := cipher.NewOFB(block, iv[:])

    var out bytes.Buffer

    writer := &cipher.StreamWriter{S: stream, W: &out}
    if _, err := io.Copy(writer, bReader); err != nil {
        panic(err)
    }

    if os.WriteFile("doc-encrypted.docx", out.Bytes(), 0644) != nil {
        panic(err)
    }

当我尝试使用此命令解密它时

openssl enc -in doc-encrypted.docx -out doc-decryted.docx -d -aes-256-ofb

它给出错误 bad magic number


正确答案


您的 openssl 语句缺少密钥和 iv 的规范。对于解密,需要以下 openssl 语句:

openssl enc -in doc-encrypted.docx -out doc-decryted.docx -d -aes-256-ofb -K 5445535450415353574f5244313233345445535450415353574f524431323334 -iv 00000000000000000000000000000000

-k选项指定十六进制编码的密钥,-iv指定十六进制编码的iv,s。 enc

通过此更改,可以使用 openssl 语句对 go 代码生成的密文进行解密。

请记住,使用静态 iv 是不安全的。通常,为每个加密生成一个随机 iv。这不是秘密,通常与密文连接:iv|ciphertext,以便在解密过程中可用。有关示例,请参阅 NewOFB 的文档(无文件 i/o)。

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>