我正在尝试在本地运行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)
}
}
2条答案
按热度按时间erhoui1w1#
这个问题是关于密钥文件的。文件的开头有一些问题(比如文件开头的UTF-8 BOM或者类似的问题),就像@SteffenUllrich提到的那样。为了解决这个问题,我在密钥文件的上面添加了一个空行,它就工作了。
最后,密钥如下所示:
mfuanj7w2#
对我来说,额外的字节被添加在最后,而从终端串行化数据,使用下面的片段来纠正它。