go - 未能在 key 中找到任何 PEM 数据

标签 go ssl

我正在尝试在本地运行 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)
    }
}

最佳答案

问题出在 key 文件上。正如@SteffenUllrich 提到的,文件的开头有一些问题(例如文件开头的 UTF-8 BOM 或类似内容)。为了解决这个问题,我在 key 文件上方添加了一个空行,它起作用了。

最后, key 看起来像:

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

关于go - 未能在 key 中找到任何 PEM 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57596920/

相关文章:

ssl - 在lighttpd上配置https

node.js - 在特定端口上为 Nodejs 配置 NGINX (Engintron) HTTPS 到 HTTP

testing - 测试中的静态文件

c# - WCF DualHTTPBINDING 消息安全

ssl - 使用完整的 SSL 免费将 Cloudflare 连接到 Heroku——上传证书时出现问题

ssl - 如何删除 debian 8 上的自 ssl 证书?

arrays - 在 Go 中将指针转换为数组

pointers - 如何将指针分配给 Go map

php - golang 相当于 PHP crypt()

go - 如何在 Golang 中响应所有字段包含带有标签 omitempty 的字段?