首頁 > 後端開發 > Golang > 如何在 Go 中產生 RSA 金鑰對:與 OpenSSL 的比較?

如何在 Go 中產生 RSA 金鑰對:與 OpenSSL 的比較?

DDD
發布: 2024-12-10 06:50:14
原創
239 人瀏覽過

How to Generate RSA Key Pairs in Go: A Comparison with OpenSSL?

使用Go 和Openssl 等效項產生RSA 金鑰

使用Go 和Openssl 等效項產生RSA 金鑰

了解Openssl 指令

  • 所提供的RSAOpenSSL 指令
  • 所提供的RSAOpenSSL 指令密鑰配對並將私鑰和公鑰保存到單獨的檔案中。它需要兩個參數:

$1:金鑰檔案的名稱(例如,「key.rsa」)

$2:RSA 金鑰的大小(以位元為單位) (例如,4096)

  1. 實作於Go
  2. 要在Go 中複製此功能,我們需要執行以下步驟:
  3. 產生RSA 密鑰對
  4. 擷取公鑰元件
將金鑰轉換為PKCS#1 ASN.1 DER格式

編碼為PEM塊

將密鑰寫入文件
package main

import (
    "crypto/rand"
    "crypto/rsa"
    "crypto/x509"
    "encoding/pem"
    "fmt"
    "io/ioutil"
)

func main() {
    // Define filename and bit size
    filename := "key"
    bitSize := 4096

    // Generate RSA key
    key, err := rsa.GenerateKey(rand.Reader, bitSize)
    if err != nil {
        panic(err)
    }

    // Extract public key
    pub := key.Public()

    // Convert to PKCS#1 DER format
    keyPEM := pem.EncodeToMemory(
        &pem.Block{
            Type:  "RSA PRIVATE KEY",
            Bytes: x509.MarshalPKCS1PrivateKey(key),
        },
    )

    pubPEM := pem.EncodeToMemory(
        &pem.Block{
            Type:  "RSA PUBLIC KEY",
            Bytes: x509.MarshalPKCS1PublicKey(pub.(*rsa.PublicKey)),
        },
    )

    // Write keys to files
    err = ioutil.WriteFile(filename+".rsa", keyPEM, 0700)
    if err != nil {
        panic(err)
    }

    err = ioutil.WriteFile(filename+".rsa.pub", pubPEM, 0755)
    if err != nil {
        panic(err)
    }

    fmt.Println("RSA key pair generated and written to files.")
}
登入後複製

Go代碼:

輸出:

-----BEGIN RSA PRIVATE KEY-----
...
-----END RSA PRIVATE KEY-----
登入後複製
程式將建立兩個包含以下內容的檔案:

key.rsa:

-----BEGIN RSA PUBLIC KEY-----
...
-----END RSA PUBLIC KEY-----
登入後複製
key.rsa.pub:

以上是如何在 Go 中產生 RSA 金鑰對:與 OpenSSL 的比較?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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