微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Golang httptls 通信,带证书请求小实例

package wget

import (
	"crypto/tls"
	"crypto/x509"
	"io"
	"net/http"
	"os"
)

func client(rootCa,rootKey string) *http.Client {
	var tr *http.Transport
	certs,err := tls.LoadX509KeyPair(rootCa,rootKey)
	if err != nil {
		tr = &http.Transport{
			TLSClientConfig: &tls.Config{InsecureSkipVerify: true},}
	} else {
		ca,err := x509.ParseCertificate(certs.Certificate[0])
		if err != nil {
			return &http.Client{Transport: tr}
		}
		pool := x509.NewCertPool()
		pool.AddCert(ca)

		tr = &http.Transport{
			TLSClientConfig: &tls.Config{RootCAs: pool},}

	}
	return &http.Client{Transport: tr}
}

func Wget(url,name,rootCa,rootKey string) (bool,error) {
	resp,err := client(rootCa,rootKey).Get(url)
	if err != nil {
		return false,err
	}
	defer resp.Body.Close()
	File,err := os.Create(name)
	if err != nil {
		return false,err
	}
	io.copy(File,resp.Body)
	File.Close()
	return true,nil
}

原文地址:https://www.jb51.cc/go/189821.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐