首頁 > 後端開發 > Golang > PHP openssl des-ede3-cbc 到 Golang

PHP openssl des-ede3-cbc 到 Golang

WBOY
發布: 2024-02-08 23:10:20
轉載
652 人瀏覽過

PHP openssl des-ede3-cbc 到 Golang

PHP openssl des-ede3-cbc 到 Golang是一篇介绍在PHP和Golang之间进行加密算法转换的文章。在这篇文章中,php小编子墨将详细讲解如何使用openssl库中的des-ede3-cbc算法,在PHP中对数据进行加密,然后将加密后的数据传输到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}

以上是PHP openssl des-ede3-cbc 到 Golang的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:stackoverflow.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板