登录
首页 >  Golang >  Go问答

使用Golang实现PHP的openssl des-ede3-cbc算法

来源:stackoverflow

时间:2024-02-06 12:24:25 453浏览 收藏

学习Golang要努力,但是不要急!今天的这篇文章《使用Golang实现PHP的openssl des-ede3-cbc算法》将会介绍到等等知识点,如果你想深入学习Golang,可以关注我!我会持续更新相关文章的,希望对大家都能有所帮助!

问题内容

我有以下 php 代码:

$l = ceil(strlen($message) / 8) * 8;
$enc = substr(openssl_encrypt($message . str_repeat("\0", $l - strlen($message)), 'des-ede3-cbc', $key, openssl_raw_data, "\0\0\0\0\0\0\0\0"), 0, $l);

如何在 go 中实现它?

我尝试了这样的方法,但得到了不同的结果:

block, err := des.NewTripleDESCipher(key)
    if err != nil {
        fmt.Printf("err: %s", err)
        return
    }

    // Create initialization vector from rand.reader
    iv := make([]byte, des.BlockSize)
    if _, err := io.ReadFull(rand.Reader, iv); err != nil {
        fmt.Printf("err: %s", err)
        return
    }

    // Encrypt with CBC mode
    cipherText := make([]byte, len(plainText))
    encryptMode := cipher.NewCBCEncrypter(block, iv)
    encryptMode.CryptBlocks(cipherText, plainText)

    str := hex.EncodeToString(cipherText)

    fmt.Println("Cipher text: %s", str)

正确答案


发现错误了。我使用 rand.Reader 作为 iv 但在 PHP 中是不同的。

var iv = []byte{0, 0, 0, 0, 0, 0, 0, 0}

到这里,我们也就讲完了《使用Golang实现PHP的openssl des-ede3-cbc算法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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