ssl 在项中找不到任何PEM数据

qvsjd97n  于 2022-11-14  发布在  其他
关注(0)|答案(2)|浏览(234)

我正在尝试在本地运行HTTPS rest服务器。我遵循了以下帮助:Golang TLS
当使用上面教程中的自签名证书时,它可以正常工作。
这些证书在apache服务器上可以正常工作,但在我的本地Go服务器上就不行了。

package main
import (
    "log"
    "net/http"
)

func HelloServer(w http.ResponseWriter, req *http.Request) {
    w.Header().Set("Content-Type", "text/plain")
    _, _ = w.Write([]byte("This is an example server.\n"))
}

func main() {
    //https://localhost:443/hello
    http.HandleFunc("/hello", HelloServer)
    err := http.ListenAndServeTLS(":443",
        "../../../../../sslcert/server.crt",
        "../../../../../sslcert/server.key",
        nil)
    if err != nil {
        log.Fatal("ListenAndServe: ", err)
    }
}
erhoui1w

erhoui1w1#

这个问题是关于密钥文件的。文件的开头有一些问题(比如文件开头的UTF-8 BOM或者类似的问题),就像@SteffenUllrich提到的那样。为了解决这个问题,我在密钥文件的上面添加了一个空行,它就工作了。
最后,密钥如下所示:

<Empty line>
-----BEGIN RSA PRIVATE KEY-----
wlWPpSnGEdNjRapfW/6+xzjDVAaKC41c5b07OAviFchwqGI+88
aZGwBJnTgkbsLddddddd=
-----END RSA PRIVATE KEY-----
mfuanj7w

mfuanj7w2#

对我来说,额外的字节被添加在最后,而从终端串行化数据,使用下面的片段来纠正它。

func convert(input []byte) (output []byte) {
    if input[len(input)-1] == 0 {
        input = input[:len(input)-1]
    }
    return input
}

相关问题