我試圖以編程方式通過以下方式完成步驟 (2):1. openssl genrsa -out signing.pem 20482. openssl rsa -in signing.pem -outform PEM -pubout -out signing.pub.pem以下是一個簡單的函數,它讀取私鑰并嘗試提取公鑰。但是,我在匹配第二步時遇到了困難,因為以編程方式生成的公鑰不同于基于 openssl CLI 的公鑰,我確定一定有錯誤,請幫助我。謝謝 func main() { priv, err := ioutil.ReadFile("signing.pem") block, _ := pem.Decode([]byte(priv)) if block == nil || block.Type != "RSA PRIVATE KEY" { log.Fatal("failed to decode PEM block containing public key") } key, err := x509.ParsePKCS1PrivateKey(block.Bytes) if err != nil { log.Fatal(err) } publicKeyDer := x509.MarshalPKCS1PublicKey(&pub.PublicKey) pubKeyBlock := pem.Block{ Type: "PUBLIC KEY", Headers: nil, Bytes: publicKeyDer, } pubKeyPem := string(pem.EncodeToMemory(&pubKeyBlock)) fmt.Println(pubKeyPem)}如果有人想檢查代碼并嘗試一下,那么這里是鏈接:https://play.golang.org/p/rKerkh-31KI
- 1 回答
- 0 關注
- 296 瀏覽
添加回答
舉報
0/150
提交
取消