SSL证书

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

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

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

更多的免费SSL还有:

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

一、集成现有面板申请

网站:

  1. https://www.buypass.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

网站:

  1. https://github.com/acmesh-official/acme.sh
  2. acme.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 buypass

2.2 Web验证

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

acme.sh  --issue  -d wzfou.com -d www.wzfou.com  --webroot  /home/wwwroot/wzfou.com

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

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

acme.sh  --issue -d wzfou.com   --standalone

2.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 wzfou.com -d www.wzfou.com

以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 wzfou.com  -d www.wzfou.com

导入的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 wzfou.com \
--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 wzfou.com \
--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 ssl http2;
        #listen [::]:443 ssl http2;
        server_name _;
        index index.html index.htm index.php;
        root  /home/wwwroot/default;
  
        ssl_certificate /usr/local/nginx/conf/ssl/ipssl/wzfouip.crt;
        ssl_certificate_key /usr/local/nginx/conf/ssl/ipssl/wzfouip.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
        ssl_prefer_server_ciphers on;
        ssl_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";
        ssl_session_cache builtin:1000 shared:SSL:10m;
        # openssl dhparam -out /usr/local/nginx/conf/ssl/dhparam.pem 2048
        ssl_dhparam /usr/local/nginx/conf/ssl/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 letsencrypt
acme.sh --set-default-ca  --server zerossl

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

acme.sh --issue -d example.com --dns dns_cf --server letsencrypt

4.2 更新证书

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

acme.sh --renew -d wzfou.com --force

文章出自:挖站否 https://wzfou.com/buypass-ssl/,版权所有。本站文章除注明出处外,皆为作者原创文章,可自由引用,但请注明来源。

文章更新于: 2022年8月20日 下午3:40

Qi

关于站长(Qi),2008年开始混迹于免费资源圈中,有幸结识了不少的草根站长。之后自己摸爬滚打潜心学习Web服务器、VPS、域名等,兴趣广泛,杂而不精,但愿将自己经验与心得分享出来与大家共勉。

查看评论