golang lego获取https证书

git地址:

https://github.com/go-acme/legoicon-default.png?t=N7T8https://github.com/go-acme/lego

说明:

获取 Let's Encrypt 证书 有3种方式:

  1. 通过80端口方式获取。
  2. 通过https的443端口方式获取。
  3. 通过 云服务商增加dns解析获取,支持泛域名。

通过80端口方式获取

// You'll need a user or account type that implements acme.User
type MyUser struct {
	Email        string
	Registration *registration.Resource
	key          crypto.PrivateKey
}

func (u *MyUser) GetEmail() string {
	return u.Email
}
func (u MyUser) GetRegistration() *registration.Resource {
	return u.Registration
}
func (u *MyUser) GetPrivateKey() crypto.PrivateKey {
	return u.key
}

func main() {
	// 创建key 并指定邮箱
	privateKey, err := ecdsa.GenerateKey(elliptic.P256(), rand.Reader)
	if err != nil {
		log.Fatal(err)
	}
	myUser := MyUser{
		Email: "you@yours.com",
		key:   privateKey,
	}
	config := lego.NewConfig(&myUser)

	// 设置 ca服务器地址
	config.CADirURL = lego.LEDirectoryProduction
	config.Certificate.KeyType = certcrypto.RSA2048

	// 初始化
	client, err := lego.NewClient(config)
	if err != nil {
		log.Fatal(err)
	}
    //不同处==========================================================
	//http的方式
	err = client.Challenge.SetHTTP01Provider(http01.NewProviderServer("", "80"))
	if err != nil {
		log.Fatal(err)
	}
   //不同处==========================================================

	// 新用户注册
	reg, err := client.Registration.Register(registration.RegisterOptions{TermsOfServiceAgreed: true})
	if err != nil {
		log.Fatal(err)
	}
	myUser.Registration = reg
    
    //设置域名
	request := certificate.ObtainRequest{
		Domains: []string{"mydomain.com"},
		Bundle:  true,
	}
     //获取证书
	certificates, err := client.Certificate.Obtain(request)
	if err != nil {
		log.Fatal(err)
	}

	fmt.Printf("%#v\n", certificates)

}

通过https的443端口方式获取。


    //不同处==========================================================
	//https的方式
	err = client.Challenge.SetTLSALPN01Provider(tlsalpn01.NewProviderServer("", "443"))
	if err != nil {
		log.Fatal(err)
	}
   //==========================================================

通过 云服务商增加dns解析获取(阿里云),支持泛域名。



    //不同处==========================================================
	//dns的方式(阿里云)
	dnsConfig.APIKey = 阿里云的appKey
	dnsConfig.SecretKey = 阿里云的SecretKey
	dnsProviderCfg, err := alidns.NewDNSProviderConfig(dnsConfig)
	err = client.Challenge.SetDNS01Provider(dnsProviderCfg)
	if err != nil {
		log.Fatal(err)
	}
   //==========================================================

视频分享

go用lego获取ssl证书_哔哩哔哩_bilibiligo用lego获取ssl证书.https://blog.csdn.net/jichenggong5813/article/details/137131938, 视频播放量 2、弹幕量 0、点赞数 1、投硬币枚数 0、收藏人数 0、转发人数 0, 视频作者 jicg33, 作者简介 做自己就行 ,相关视频:稳 定月 入 7. 5w 左右,代价 是肯吃 苦熬 夜,选择 大于 努力,其实 富 起来 也就 一两 年!,【模型师老原儿】耳朵进虫怎么办!?这三种下意识的行为别乱做!,数字签名和CA数字证书的核心原理和作用,影刀RPA零基础入门教程(2024最新版):05 网页操作自动化,每日常识练习#82,10分钟速通计算机网络 每个开发者都具备的计算机常识,99%的人回家自学废掉的原因,新版C#从入门到精通全套视频教程(180集全),影刀RPA零基础入门教程(2024最新版):07 软件操作自动化,山东女孩复读五年还在纠结选科,短短一分钟震惊老张两次!icon-default.png?t=N7T8https://www.bilibili.com/video/BV1Uq421w7Pq

代码分享

https://gitee.com/jicg/wx-proxy/raw/master/mylego/lego.goicon-default.png?t=N7T8https://gitee.com/jicg/wx-proxy/raw/master/mylego/lego.go

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jicg33

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值