donglianjiang9321 2016-05-19 07:16 采纳率: 0%
浏览 238
已采纳

如何在golang中用密码创建rsa私钥[关闭]

How create rsa private key with passphrase in golang? In golang, I'm new. I read the documentation for the crypto package. The answer is not found. Thanks!

  • 写回答

1条回答 默认 最新

  • duanqiang7631 2016-05-19 07:25
    关注

    First step, generate a private key. Second step, convert it to PEM format. Third step, encrypt the PEM.

    All can be done using Golang's standard library, which is very complete. The code is nothing difficult so I put it here. All there is to it is to know which functions to use.

    import (
        "crypto/rand"
        "crypto/rsa"
        "crypto/x509"
        "encoding/pem"
    )
    
    func PrivateKeyToEncryptedPEM(bits int, pwd string) ([]byte, error) {
        // Generate the key of length bits
        key, err := rsa.GenerateKey(rand.Reader, bits)
        if err != nil {
            return nil, err
        }
    
        // Convert it to pem
        block := &pem.Block{
            Type:  "RSA PRIVATE KEY",
            Bytes: x509.MarshalPKCS1PrivateKey(key),
        }
    
        // Encrypt the pem
        if pwd != "" {
            block, err = x509.EncryptPEMBlock(rand.Reader, block.Type, block.Bytes, []byte(pwd), x509.PEMCipherAES256)
            if err != nil {
                return nil, err
            }
        }
    
        return pem.EncodeToMemory(block), nil
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?