代码拉取完成,页面将自动刷新
package golang
import (
"crypto/tls"
"crypto/x509"
"io/ioutil"
)
// generateTLSConfig generates a new TLS config based on given
// certificate path and key path.
func generateTLSConfig(certPath, keyPath, caCertPath string) (*tls.Config, error) {
// Load certificate
certificate, err := tls.LoadX509KeyPair(certPath, keyPath)
if err != nil {
return nil, err
}
// Create certificate pool
certPool := x509.NewCertPool()
rootCert, err := ioutil.ReadFile(caCertPath)
if err != nil {
return nil, err
}
// Append cert to cert pool
if ok := certPool.AppendCertsFromPEM(rootCert); !ok {
return nil, errCertNotAppended
}
return &tls.Config{
ClientAuth: tls.RequireAndVerifyClientCert,
Certificates: []tls.Certificate{certificate},
ClientCAs: certPool,
}, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。