草庐IT

认证证书

全部标签

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

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

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

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

ssl - 使用 go-gin 以编程方式自动接受证书

我正在使用golanggo-gin服务器托管应用程序。前端和后端都通过https工作,并且都是独立的项目。前端对基于restAPI的后端进行ajax调用。如果我清除浏览器缓存(GoogleChrome)并尝试加载UI,它最初不会与后端API通信。然后在另一个选项卡中,我点击基本url(https://localhost:8080/)接受证书,然后它就可以工作了。有什么办法可以避免这种情况吗?我希望前端应该自动接受证书而不是提示它。 最佳答案 在tls.Config中,您可以找到Certificates属性,这可能对您的情况有帮助:C

performance - 使用 TLS/SSL 可信证书提高性能

我们正在为企业开发基于云的服务。我负责的组件分为三个部分,一个简单的WEB和assets服务器,一个API服务器(都是用Go写的))和实际的WEB应用程序(基于AngularJS)。WEB应用程序流程非常简单,它从Web服务器下载Assets和源文件,从API服务器下载数据。直到昨天,我们一直在使用一个简单的自签名SSL证书,我一直在责备自己,因为整个应用程序很慢,我所说的慢是指非常慢(我没想到实际测量它,但加载Assets和源可能需要大约3/4秒,加载数据可能需要更多时间。昨天我们设法开始使用TrustedSSL证书(通过Let'sEncrypt获得),突然间我注意到性能有了显着提高

来自 x509 证书的 golang 主题 DN

有什么简单的方法可以从x509证书中以字符串形式获取完整的主题DN(或颁发者DN)?我无法在pkix.Name中找到任何类似“.String()”的方法 最佳答案 解决方案(感谢同事):varoid=map[string]string{"2.5.4.3":"CN","2.5.4.4":"SN","2.5.4.5":"serialNumber","2.5.4.6":"C","2.5.4.7":"L","2.5.4.8":"ST","2.5.4.9":"streetAddress","2.5.4.10":"O","2.5.4.11":"

windows - Golang httpClient CA证书默认位置?

我有一个go程序,它使用httpClient连接到内部API(它全部由swagger-codegen生成)。内部API使用https和我们内部CA的内部证书。在我的Windows笔记本电脑上,无需指定任何CA即可正常工作。在Linux服务器上,它因x509:certificatesignedbyunknownauthority错误而失败。我相信我们的Windows公司笔记本电脑默认安装了CA,并且golang无需任何配置即可获得这些CA。因此我想知道go在Linux和Windows上检查CA的位置,这样我就可以比较两个操作系统之间的设置并在上安装正确的CALinux.

go命令访问自签名证书

我正在使用带有自签名证书的自托管Git(gitea)的Go。然而,对于自签名证书,大多数Go命令都无法正常工作,包括“gomod”。在执行任何其他gomod命令之前,我必须执行“goget-insecure....”。我什至无法执行“golist”,因为它似乎不接受-insecure标志。大多数IDE工具都无法正常工作,尤其是GoLand。解决此类问题的最佳方法是什么?我是否必须获取证书并在本地添加到受信任的证书?或者还有另一种方法可以解决这个问题吗? 最佳答案 正如@Vorsprung所说,我作为我们的MIS提供自签名CA,并在我

ssl - 是否有用于解码 ASN.1 格式的 TLS 证书的接口(interface)

我正在解析从PCAP文件中获取的TLS记录。我有ASN.1格式的TLS证书字节(在[]byte中)。我想将这个byteslice解码为一个有用的结构(避免手动解析ASN.1)。我似乎无法找到遵循RFC的TLS证书的接口(interface)在encoding/asn1也不crypto/tls.这是在我找不到的地方创建的还是我需要自己编写? 最佳答案 该结构在x509package中 关于ssl-是否有用于解码ASN.1格式的TLS证书的接口(interface),我们在StackOver

go - 检查 X509 证书是否与 CertificateRequest (CSR) 匹配

如何在Go中检查x509证书是否与CSR匹配(如果证书是基于特定CSR生成的)?我是否需要从CSR生成新证书并进行比较? 最佳答案 如果您的签名请求是DER格式,那么您可以使用标准库中的几个函数;首先解析CSR(https://golang.org/pkg/crypto/x509/#ParseCertificateRequest),然后解析证书(https://golang.org/pkg/crypto/x509/#ParseCertificate)。解析后,您可以比较公钥值。标准但重要的安全说明:请注意,这无论如何都不会验证证书。

go - 如何将私钥添加到证书

我正在尝试使用Go多合一实用程序创建csr,发送它,然后(在安全人员批准后)获得签名证书,最后创建证书+private以将其添加到浏览器或系统。现在我可以做所有的事情直到最后剪辑:将私有(private)添加到签名证书中。使用openssl我可以通过以下方式做到这一点:opensslpkcs12-export-outsergo.kurbanov.p12-insergo.kurbanov.crt-inkeysergo.kurbanov.key-name"SergoKurbanov"有人可以建议在Go中如何做吗?附言我正在使用Dogtag证书系统 最佳答案