登录
首页 >  Golang >  Go问答

如何解决 NewCBCDecrypter 示例中的无效密钥问题?

来源:stackoverflow

时间:2024-02-15 13:27:23 474浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《如何解决 NewCBCDecrypter 示例中的无效密钥问题?》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我找到了cbc解密器的使用示例: https://golang.org/pkg/crypto/cipher/#newcb​​cdecrypter

package main

import (
    "crypto/aes"
    "crypto/cipher"
    "encoding/hex"
    "fmt"
)

func main() {
    key, _ := hex.DecodeString("6368616e676520746869732070617373")
    ciphertext, _ := hex.DecodeString("73c86d43a9d700a253a96c85b0f6b03ac9792e0e757f869cca306bd3cba1c62b")
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err)
    }
    if len(ciphertext) < aes.BlockSize {
        panic("ciphertext too short")
    }
    iv := ciphertext[:aes.BlockSize]
    ciphertext = ciphertext[aes.BlockSize:]

    if len(ciphertext)%aes.BlockSize != 0 {
        panic("ciphertext is not a multiple of the block size")
    }
    mode := cipher.NewCBCDecrypter(block, iv)
    mode.CryptBlocks(ciphertext, ciphertext)
    fmt.Printf("%s\n", ciphertext)
}

效果很好。但是,如果我修改密钥使其无效,那么它会返回一些奇怪的字符而不是抛出错误。 如果密钥无效,如何通过抛出错误来使其对程序员更加友好?


正确答案


如果密钥无效,如何通过抛出错误来使其对程序员更加友好?

你不能。这根本不是这个东西的工作原理。您提供一个密钥,该密钥用于解密输入。这里没有“正确”或“错误”的密钥,这里只有一个密钥。

您也许能够检查解密的输出:如果您知道输出总是以某个魔术前缀开头,或者是格式良好的 XML 或任何您在解密后可以可靠检查的内容,则可能会失败。但密钥的错误或正确实际上并没有什么本质的区别。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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