我正尝试在本地运行HTTPS rest服务器。我遵循了这个帮助:Golang TLS
在使用上述教程中的自签名证书时,它工作得很好。但是,当我将这些证书替换为我从GoDaddy为我的一个网站生成的证书时,我得到的是ListenAndServe: tls: failed to find any PEM data in key input
这些证书在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)
}
}发布于 2019-08-23 01:46:32
问题出在密钥文件上。正如@SteffenUllrich提到的,文件的开头有一些问题(比如文件开头的UTF-8 BOM或类似的问题)。为了解决这个问题,我在密钥文件的上方添加了一个空行,它就起作用了。
最后,关键看起来像:
<Empty line>
-----BEGIN RSA PRIVATE KEY-----
wlWPpSnGEdNjRapfW/6+xzjDVAaKC41c5b07OAviFchwqGI+88
aZGwBJnTgkbsLddddddd=
-----END RSA PRIVATE KEY-----https://stackoverflow.com/questions/57596920
复制相似问题