1 Star 0 Fork 0

小狮子beta / gosdk

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
server_listener.go 789 Bytes
一键复制 编辑 原始数据 按行查看 历史
小狮子beta 提交于 2019-08-18 09:09 . init
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
}
Go
1
https://gitee.com/azurelion/gosdk.git
git@gitee.com:azurelion/gosdk.git
azurelion
gosdk
gosdk
master

搜索帮助