我正在尝试在本地运行 HTTPS 休息服务器。我遵循了这个帮助: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)
}
}
Run Code Online (Sandbox Code Playgroud)
imp*_*ble 12
问题出在密钥文件上。正如 @SteffenUllrich 提到的,文件的开头有一些问题(例如文件开头的 UTF-8 BOM 或类似问题)。为了解决这个问题,我在密钥文件上方添加了一个空行,它起作用了。
最后,密钥如下所示:
<Empty line>
-----BEGIN RSA PRIVATE KEY-----
wlWPpSnGEdNjRapfW/6+xzjDVAaKC41c5b07OAviFchwqGI+88
aZGwBJnTgkbsLddddddd=
-----END RSA PRIVATE KEY-----
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7668 次 |
| 最近记录: |