duanhemou9834 2018-12-14 10:49
浏览 128
已采纳

如何在Go HTTP请求中添加PKI证书?

I'm trying to add a PKI certificate to an HTTP client, so that all requests made by it are authenticated to the services they are talking to. I can instantiate an HTTP client by executing:

client := &http.Client{
    Transport: &http.Transport{
        Proxy:                 http.ProxyFromEnvironment,
        TLSClientConfig: &tls.Config{
            // TLS Implementation
        }
    }
}

This uses the default RoundTripper implementation, which includes a TLS configuration section. However the TLS configuration appears to be shared between client and server. Which of these settings do I need to add so that I can call other PKI services?

  • 写回答

1条回答 默认 最新

  • doulan1866 2018-12-14 10:56
    关注

    It appears that one only needs to add the Certificates attribute to the TLS configuration:

    Certificates: []tls.Certificate{cert}
    

    Where cert can be created using the helper function:

    cert, err := tls.LoadX509KeyPair(*certFile, *keyFile)
    

    Where certFile and keyFile are two strings which point to pem files on disk. As mentioned by Peter, you can also implement GetClientCertificate, but that is unnecessary for implementing PKI support.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭