如何在 Go 中验证 RSA 密钥长度?

How to verify RSA key length in Go?

我正在使用以下函数在 Go 中设置一个 https 服务器。

err := http.ListenAndServeTLS(":8080", key, cert, nil)
if err != nil {
    log.Fatal("error...")
}

其中key和cert分别是自签名的密钥和证书文件。 我的问题是,为了安全起见,我需要验证它们的自签名密钥是否具有 2048 位大小(或更多)。 我如何在 Go 中安全、干净地检查这个?

package main

import (
    "crypto/ecdsa"
    "crypto/rsa"
    "crypto/tls"
    "log"
    "net/http"
)

func main() {
    certFile := "/tmp/cert.pem"
    keyFile := "/tmp/key.pem"

    cert, err := tls.LoadX509KeyPair(certFile, keyFile)
    if err != nil {
        log.Fatal(err)
    }

    var bitLen int
    switch privKey := cert.PrivateKey.(type) {
    case *rsa.PrivateKey:
        bitLen = privKey.N.BitLen()
    case *ecdsa.PrivateKey:
        bitLen = privKey.Curve.Params().BitSize
    default:
        log.Fatal("unsupported private key")
    }

    if bitLen < 2048 {
        log.Fatalf("private key length is too small (size: %d)\n", bitLen)
    }

    tlsConfig := tls.Config{
        Certificates: []tls.Certificate{cert},
    }

    server := http.Server{
        Addr:      ":8080",
        TLSConfig: &tlsConfig,
    }
    if err := server.ListenAndServeTLS("", ""); err != nil {
        log.Fatal(err)
    }
}