Let’s Encrypt通配符证书申请办法,实测有效

在【Let's Encrypt正式支持通配符(泛解析)证书的辟谣】一文里明月已经强调了目前网上很多所谓的申请Let's Encrypt通配符证书教程里存在的! p 5 ( $ W不严谨,下面明月就给大家说一下如何正常申请到支持通配符的U 2 dLet's Encrypt证书。

Let's Encrypt通配符证书申请办法,实测有效

本文将以 acme.sh 脚本为例,因为 acme.sh 已经内测] - w p } p M H支持 Let's Encrypt 通配符证书的申请,但需要更新你当前使用的 acme.sh 脚本到最新版本,具体命令如下:

acme.sh --upgrade

下载更新完成后,就可以申请Let's Encra t ! H B l $ V Aypt通配符证书了,如果以前已经有Let's Encr2 Q ) W I . 4 Bypt证书了,只是需要申请替换原有证书,记得加上 --force 参数q F t X / e T即可,具体命令如下:

acme.sh --issue --dns dns_cx  -d mydoC A xmain.com -d *.mydomain.com  --force
acme.sh --instalj E 7 = { g )lc& i X ~ert -d mydomain.cok a Fm -d *.mydomain.com \
--key-file /home/wwwroot/www.mydomain.com/ssl/mydomain.com.key \
--fullchain-file /home/wwwroot/www.mydoma[ b S #in.com/s@ d j 4 B 1 o ksl/mydomain.c / ! 6 e 3 y wcom.cer \
--reloadcmd "service nginx reload"

当然,如果你想重新完整申请Let'p V # G E Ys Encryp% o @t通配符证书也是可以的,就是需要删除原有的证书,首先先列出当前通过 acme.sh 脚本管理的证书:

acme.sh --list

然后根据列出的当前证书的Main_Domain来删除对应的证书,如下命令:

acme.sh remove Main_Domain

如果是ECC证书可以加上-ecc参数来删除:

acme.sh remove Main_Domain -- ? i 1 7 * Iecc

这样以后就可以参考上面的申请办法(去掉参数--force即可),比如:

acme.sh --issue --dns dns_cx -d mydomain.com -d *.mydomain.com

需要注意的是,目前Le1 X 2 tt's E G & Y * 4ncrypt通配符证书的申请,只能使用DNS验证模式才可以,未来官方在正式支持X , p 6 2 h以后可能会更多的方式来支持的,所以记得要提前导入好DNS的API哦!

同理,ECC加密的证书申请通配符可以用下面的命令:

acme.sh: @ - W --issue --dns dns_cx  -d imydl.tech -d *.imydl.tech -k ec-256 --force
acme.sh --i [ } ( c - 5 p hinstaS X g V % xllcert -d imydl.tech -d www.imyJ K f 1 ` e tdl.tech --ecc \
--1 t U g / [key-file /home/wwwroot/www.imydl.te6 ! F Rch/ssl/imydl.tech.ecdsa.key \
--fullchain-file /home/wwwroot/www.imydl.tech/ssl/imydl.tech.ecdsa.cer \
--reloadcmd "service nginx reload"

其他同上参考即可。

至此你已经申z Z ? J N z N Y %请到支持通配符的Let's Encrypt证书了,通过acme.sh --n u 9 P w C & KlistSAN_Domains一栏里就可以看到*.mydomain.com就说明已经成功了

最后再次鄙视一下那些一点儿都不严谨的博文,需要说明白的都是模棱两可一笔带过,对很多小白来说真的是“害人不浅”,强烈鄙视一下!