BuyPass免费SSL证书申请与使用教程-acme.sh自动申请和续期SSL证书

SSL   2024年03月13日 18:55  

BuyPass是国外一家SSL证书机构,提供类似于Let’s Encrypt一样的免费SSL证书,可以无限续期。不过,相对于免费90天一续期Let’s Encrypt来说,BuyPass免费SSL证书免费时长是180天一续期,也就是说差不多就是免费半年,这对于不想频繁续期SSL的朋友是一大好处。

BuyPass免费SSL证书支持acme.,你只需要安装了acme.sh就可以快速为你的域名申请BuyPass免费SSL证书,并且可以自动续期。这篇文章就来分享一下利用acme.sh来申请并安装BuyPass免费SSL证书,除了Let’s Encrypt免费SSL证书,BuyPass免费SSL证书也是一个不错的备选方案。

更多的免费SSL还有:

ZeroSSL免费SSL证书申请与使用-支持自动续期和免费泛域名SSL证书简单三步给网站申请安装letsencrypt免费SSL证书-acme.sh自动续期免费SSL证书收集整理汇总-免费给网站添加Https安全加密访问一、集成现有面板申请

网站:

https://www..com

大部分支持申请Let’s Encrypt免费证书的建站面板或者脚本,其实都是可以直接申请BuyPass免费SSL证书的。例如我们经常用的LNMP一键安装包就可以在申请SSL证书选择BuyPass免费SSL证书。

如果你的面板或者脚本已经集成了acme.sh,但是颁发出来的不是BuyPass免费SSL证书,可以使用以下命令切换一下CA:

bash /root/.acme.sh/acme.sh --set-default-ca --server buypass二、acme.sh申请BuyPass

网站:

https://github.com/acmesh-official/acme.shacme.sh详细教程:acme.sh支持免费SSL证书整理汇总-acme.sh安装和手动切换SSL CA方法

首先是在VPS主机上安装acme.sh脚本:

curl https://get.acme.sh | sh -s email=freehao123@gmail.com

脚本自动为你创建 cronjob, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书. 安装过程不会污染已有的系统任何功能和文件, 所有的修改都限制在安装目录中: ~/.acme.sh/

2.1 切换CA

最新版本的acme.sh 默认签发的是ZeroSSL证书,你需要使用以下命令将acme.sh 默认签发证书的CA切换为BuyPass。

bash /root/.acme.sh/acme.sh --set-default-ca --server buypass2.2 Web验证

如果你的VPS主机上已经安装了Nginx或者Apache,可以用域名正常访问的话,可以选择使用Web验证的方式(注意替换你的网站的根目录):

acme.sh --issue -d -d --webroot /home/wwwroot/#或者 acme.sh --issue -d xxx. --webroot /home/wwwroot/xxx.wzfou.me

如果你还没有运行任何 web 服务, 80 端口是空闲的, 那么 acme.sh 还能假装自己是一个webserver, 临时听在80 端口, 完成验证:

acme.sh --issue -d --standalone2.3 DNS验证

如果Web验证不成功的话,可以使用DNS验证的方式。有两种方式:

一种是手动添加DNS记录。这种方式的好处是, 你不需要任何服务器, 不需要任何公网 ip, 只需要 dns 的解析记录即可完成验证. 坏处是,如果不同时配置 Automatic DNS API,使用这种方式 acme.sh 将无法自动更新证书,每次都需要手动再次重新解析验证域名所有权。

acme.sh --issue --dns -d mydomain.com \ --yes-I-know-dns-manual-mode-enough-go-ahead-please

然后, acme.sh 会生成相应的解析记录显示出来, 你只需要在你的域名管理面板中添加这条 txt 记录即可。等待解析完成之后, 重新生成证书(注意第二次这里用的是 --renew):

acme.sh --renew -d mydomain.com \ --yes-I-know-dns-manual-mode-enough-go-ahead-please

另一种是DNS API自动添加 txt 记录完成验证。这种方式除了达到了DNS验证域名的所有优点外,还是完全自动的,支持自动续期。acme.sh目前已经支持市面上绝大多数的DNS服务商了,只要DNS商提供了API就可以使用。

以CloudFlare为例,先到CloudFlare官网找到你的API。CloudFlare提供了两种API:一种是全局API,这个API权限非常大,直接就拥有账户的所有权限。执行以下命令可以将API导入到acme.sh。

导入命令如下:

export CF_Key="sdfsdfsdfljlbjkljlkjsdfoiwje"export CF_Email="freehao123@gmail.com"

另一种是专门的API,即你可以创建限制权限的API,例如仅用于修改编辑DNS的API,这样的API安全性会相对高一些。

CloudFlare专门的API导入命令如下:

export CF_Token="sdfsdfsdfljlbjkljlkjsdfoiwje"export CF_Account_ID="xxxxxxxxxxxxx"

最后,就是使用CloudFlare DNS验证的方式来完成ZeroSSL免费SSL证书的签发了。

acme.sh --issue --dns dns_cf -d -d

以DNSPOD.cn为例,先找到DNSPOD.cn的API。

然后使用以下命令将DNSPOD.cn的API导入到acme.sh。

export DP_Id="1234"export DP_Key="sADDsdasdgdsf"

最后使用DNSPOD.cn的DNS验证方式完成ZeroSSL免费SSL证书的签发。

acme.sh --issue --dns dns_dp -d -d

导入的DNS API存放在~/.acme.sh/account.conf 下次再次签发SSL证书时就不需要再次导入了。

更多的DNS API的使用方法请查看官网:https://github.com/acmesh-official/acme.sh/wiki/dnsapi

三、acme.sh安装BuyPass

acme.sh默认生成的证书都放在安装目录下: ~/.acme.sh/, 请不要直接使用此目录下的文件, 例如: 不要直接让 nginx/apache 的配置文件使用这下面的文件. 这里面的文件都是内部使用, 而且目录结构可能会变化。

正确的使用方法是使用 --install-cert 命令,并指定目标位置, 然后证书文件会被copy到相应的位置, 例如:

Apache example:acme.sh --install-cert -d \--cert-file /path/to/certfile/in/apache/cert.pem \--key-file /path/to/keyfile/in/apache/key.pem \--fullchain-file /path/to/fullchain/certfile/apache/fullchain.pem \--reloadcmd "service apache2 force-reload"Nginx example:acme.sh --install-cert -d \--key-file /path/to/keyfile/in/nginx/key.pem \--fullchain-file /path/to/fullchain/nginx/cert.pem \--reloadcmd "service nginx force-reload"

注意上面的SSL证书的路径请替换你原来的SSL证书路径。

如果原来没有SSL证书,那你在使用acme.sh安装SSL证书的命令中的路径与你的Nginx或者Apache配置文件中的SSL证书路径保持一致。演示如下:

server { listen 443 http2; #listen [::]:443 http2; server_name _; index index.html index.htm index.php; root /home/wwwroot/default; _certificate /usr/local/nginx/conf//ipssl/wzfouip.crt; _certificate_key /usr/local/nginx/conf//ipssl/wzfouip.key; _session_timeout 5m; _protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; _prefer_server_ciphers on; _ciphers "TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:TLS13-AES-128-GCM-SHA256:TLS13-AES-128-CCM-8-SHA256:TLS13-AES-128-CCM-SHA256:EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5"; _session_cache builtin:1000 shared::10m; # openssl dhparam -out /usr/local/nginx/conf//dhparam.pem 2048 _dhparam /usr/local/nginx/conf//dhparam.pem; access_log /home/wwwlogs/access.log; }

有关事项说明:

1.这里用的是 service nginx force-reload, 不是 service nginx reload, 据测试, reload 并不会重新加载证书, 所以用的 force-reload

2.Nginx 的配置 ssl_certificate 使用 /etc/nginx/ssl/fullchain.cer ,而非 /etc/nginx/ssl/<domain>.cer ,否则 SSL Labs 的测试会报 Chain issues Incomplete 错误。

3.--install-cert命令可以携带很多参数, 来指定目标文件. 并且可以指定 reloadcmd, 当证书更新以后, reloadcmd会被自动调用,让服务器生效.

4.值得注意的是, 这里指定的所有参数都会被自动记录下来, 并在将来证书自动更新以后, 被再次自动调用.

现在打开你的域名,就可以看到BuyPass免费SSL证书签发成功了,有效期为180天,到期前脚本会自动续期,无需手动操作,非常方便。

四、相关问题4.1 切换CA

如果你觉得BuyPass免费SSL证书不好用,你可以随时用以下命令切换letsencrypt或者是ZeroSSL。

acme.sh --set-default-ca --server letsencryptacme.sh --set-default-ca --server zerossl

或者你只是临时想指定某一个域名的SSL证书使用letsencrypt,可以使用以下命令签发SSL证书。

acme.sh --issue -d example.com --dns dns_cf --server letsencrypt4.2 更新证书

acme.sh会自动续期BuyPass免费SSL证书,如果你想手动更新证书的话,使用以下命令:

acme.sh --renew -d --force

域名注册
购买VPS主机

您或许对下面这些文章有兴趣:                    本月吐槽辛苦排行榜

看贴要回贴有N种理由!看帖不回贴的后果你懂得的!


评论内容 (*必填):
(Ctrl + Enter提交)   

部落快速搜索栏

各类专题梳理

网站导航栏

X
返回顶部