草庐IT

Https协议与证书

全部标签

go - 如果未提供证书,单元测试 tls.LoadX509KeyPair 将失败

cert,err:=tls.LoadX509KeyPair(os.Getenv("CERT"),os.Getenv("KEY"))iferr!=nil{returnerr}我想为包含这段代码的函数编写单元测试。但是,我的测试环境永远不会有os.Getenv("CERT")/os.Getenv("KEY")中的任何内容。这使得代码(tls.LoadX509KeyPair())返回一个错误,这不允许我测试函数。我应该如何模拟/修改此代码段? 最佳答案 这通过为certFile和keyFile定义变量然后在测试环境中覆盖它们来实现。//.

sockets - 如何在 TLS 监听器中验证对等证书

我正在编写一个TLS监听器并接受新连接。在继续之前,必须根据SHA1列表验证新连接。问题是tls.Listen()返回接口(interface)net.Listener的监听器。这意味着Accept()将产生简单的net.Conn而不是提供ConnectionState()的tls.Conn。PeerCertificates.接受的net.Conn太基础了,但是当我转换为更具体的*tls.Conn类型时,我收到运行时异常。packagemainimport("crypto/tls""fmt""net")typeServicestruct{listenernet.Listener}fun

reactjs - AWS ELB 为 https ://domain_name:8000 but accessible via public_ip:8000 返回 404

我是在AWS上部署Web应用程序的初学者,我相信我遇到了与AWSforwardport8000fromelbtoport8000ofEC2类似的问题我有一个reactjs前端和golangapi在awsec2上运行,golangapi在端口8000上运行,可以通过我的public_ip:8000访问它,并给我消息说当我访问public_ip:8000时我的golangapi正在运行。我使用弹性IP创建了public_ip。我使用负载平衡器来获得HTTPS,因为我有一些只能与HTTPS一起使用的功能。然而,当我使用我的https://domain_name:8000时向我自己的API发送

go - 简单 HTTPS 请求 : Golang returns 505, Python 和 Chrome 工作

我正在尝试使用最简单的golang代码执行HTTPgetoverTLS,并从服务器获取505响应(不支持HTTP版本)。问题是,使用简单的pythonrequests.get可以实现相同的查询。此外,我可以使用Chrome并成功执行相同的请求。有什么想法会使golang请求不同,从而导致服务器返回505吗?我意识到这个响应是特定于服务器的。使用相同的golang代码将HTTPS连接到google.com。我曾尝试使用Wireshark进行故障排除,但TLS使这变得困难。看来这一定很简单!服务器是nginx1.9.3。Golang代码:packagemainimport("fmt""ne

ssl - 从 HTTP 重定向到 HTTPS 是否有加密?

我在Go中有一个HTTPS服务器,这样用户就可以输入https://example.com在他们的浏览器中。我希望他们也能够输入“example.com”来访问我的HTTPS服务器。来自thisanswer我看到标准解决方案是运行一个重定向到https://example.com的HTTP服务器.我想知道这是否像一切都在HTTPS中一样安全。特别是,如果用户向“example.com”发送POST请求,内容在通过网络时会被加密吗? 最佳答案 对HTTP服务器的POST请求是不安全的。这包括服务器通过重定向到HTTPS服务器来响应PO

go - Docker API 调用返回 "server gave HTTP response to HTTPS client"

我有以下代码,调用API返回错误如下,我还在下面粘贴了DockerDaemon命令。我已经尝试了HTTP/HTTPS/TCP的一些组合,有/没有TLS。我哪里错了?“panic:尝试连接时发生错误:获取https://172.28.8.212:2375/v1.24/containers/json?limit=0:http:服务器向HTTPS客户端提供HTTP响应"funcmain(){varheadersmap[string]stringtr:=&http.Transport{TLSClientConfig:&tls.Config{InsecureSkipVerify:true},}c

ssl - asn1 go(客户端证书授权)

我正在尝试让客户端证书授权工作,并且在阅读https://developer.mozilla.org/en-US/docs/Web/HTML/Element/keygen之后我意识到我需要解析一些asn1。我尝试使用的结构是这样的:typePublicKeyAndChallengestruct{Spkiasn1.BitStringChallengeasn1.BitString}typeSignedPublicKeyAndChallengestruct{PublicKeyAndChallengePublicKeyAndChallengeSignitureAlgorithmasn1.Bit

区块链学习笔记(3)BTC协议

假设有一个大家都信任的中心化机构想要发行数字货币。该机构由用自己的私钥签名后后发行,任何人都可以通过公钥验证该货币是否为真。买东西的时候,购买者可以将数字货币发送给卖方,卖方可以也可以通过公钥验证该货币为真后即可完成支付的过程。此方案没有用到区块链技术,使用的是密码学中的非对称加密公私钥体系。但该方案存在一个明显漏洞:不同于现实中的货币,交易者可以对手中的数字货币进行复制,使得一张数字货币可以重复使用。花两次攻击/双花攻击(doublespendingattack)数字货币面临的主要挑战就是怎么应对doublespendingattack。如果如下图所示,对每一个发行的数字货币进行编号。同时,

ssl - 使用自签名证书的 TLS 连接失败

当使用我自己的“开发人员”证书访问内部服务在我的笔记本电脑上本地运行时,以下简化的测试用例代码有效如果我在远程机器上运行动态生成的证书(所有这些都由我组织中的一个单独的团队处理),它会失败并显示400和“没有发送必需的SSL证书”错误但如果我在远程机器上使用curl,并指定与我的Go代码中引用的证书相同的证书,它将起作用所以似乎证书不是问题,而是Go代码,但这本身似乎不是问题,因为它在本地使用我自己的证书packagemainimport("crypto/tls""crypto/x509""fmt""io/ioutil""net/http""os""time")funcmain(){t

Go - Web 服务器在同一端口上监听多个协议(protocol)(HTTP 和 RTMP)

我正在尝试在Go中实现RTMP协议(protocol)以配合我的Web应用程序,但是我似乎无法找到在同一端口上同时处理HTTP和RTMP的解决方案。这个想法是这样的。packagemainimport("fmt""io""net/http")funcmain(){http.HandleFunc("/",func(whttp.ResponseWriter,r*http.Request){io.WriteString(w,"Hello!")})http.HandleFunc("/rtmp",func(whttp.ResponseWriter,r*http.Request){//RTMPha