跳到主要内容
版本:1.0

给域名配置 HTTPS

HTTPS 基本设置

前置条件

Websoft9 虽然预装 HTTPS 所需的环境,但配置 HTTPS 还有两个因素是用户需要完成的:

  • 开启服务器安全组的 443 端口
  • 网站可以通过 HTTP 的方式访问域名

具体以上条件后,便可以登录服务器配置 HTTPS。此处提供两种方案,请根据实际情况选择:

方案一:自动免费证书配置

Websoft9 预制 Let's Encrypt 免费的证书部署程序,只需一条命令就可以启动证书部署.

自动部署证书程序会读取已有 HTTP 配置,故请确保配置文件中 ServerName 和 ServerAlias 中配置域名绑定

  1. 连接服务器,运行自动部署证书命令

    sudo certbot
  2. 根据提示输入或选择正确的项,直至提示成功

  3. 测试 HTTPS 是否生效

方案二:自行上传证书配置

下面详细说明上传证书的配置方案:

  1. 将可用的证书上传到服务器证书目录:/data/cert(没有cert目录可以自己新建)

  2. 打开虚拟主机配置文件,插入 HTTP 配置段

    • 以 Nginx 为例,向虚拟主机配置文件 /etc/nginx/conf.d/default.conf 中插入下方的 HTTPS template 到*server*段落中

      #-----HTTPS template start------------
      listen 443 ssl;
      ssl_certificate /data/cert/xxx.crt;
      ssl_certificate_key /data/cert/xxx.key;
      ssl_trusted_certificate /data/cert/chain.pem;
      ssl_session_timeout 5m;
      ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
      ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
      ssl_prefer_server_ciphers on;
      #-----HTTPS template end------------
    • 以 Apache 为例,向虚拟主机配置文件为 /etc/httpd/conf.d/vhost.conf 中插入下面的 HTTPS template 到文件中

      #-----HTTPS template start------------
      <VirtualHost *:443>
      ServerName www.mydomain.com
      DocumentRoot "/data/wwwroot/default"
      #ErrorLog "logs/www.mydomain.com-error_log"
      #CustomLog "logs/www.mydomain.com-access_log" common
      <Directory "/data/wwwroot/default">
      Options Indexes FollowSymlinks
      AllowOverride All
      Require all granted
      </Directory>
      SSLEngine on
      SSLCertificateFile /data/cert/www.mydomain.com.crt
      SSLCertificateKeyFile /data/cert/www.mydomain.com.key
      SSLCertificateChainFile /data/cert/www.mydomain.com_chain.crt
      </VirtualHost>
      #-----HTTPS template end------------
  3. 修改配置文件中相关项,并保存。

    • ServerName: 首选域名

    • ServerAlias: 可选域名

    • DocumentRoot: 应用目录,例如:/data/wwwroot/wordpress

    • Directory:应用目录,同上

    • SSLCertificateFile:证书路径

    • SSLCertificateKeyFile:证书私钥路径

    • SSLCertificateChainFile:证书链文件

    证书文件的后缀一般是 .crt 或者 .pem;私钥的后缀一般是:.key。错误的路径会导致服务无法启动。

  4. 重启服务

    systemctl restart nginx
    systemctl restart httpd

HTTPS 特殊方案

CDN 或全站加速开启 HTTPS

需要根据云平台参考文档设置。一般来说,此场景下有两个地方需要设置 HTTPS:

  1. CDN/全站加速的控制台需设置 HTTPS
  2. 服务器中的应用需设置 HTTPS

需要注意的是,两端 HTTPS 必须使用同一套证书。

HTTP 自动跳转 HTTPS(Apache)

建议在网站根目录下的.htacesss文件中增加redirect规则

# 全部跳转
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://www.yourdomain.com/$1 [R,L]

# 指定域名跳转
RewriteEngine On
RewriteCond %{HTTP_HOST} ^yourdomain\.com [NC]
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://www.yourdomain.com/$1 [R,L]

# 指定某个目录跳转
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteCond %{REQUEST_URI} folder
RewriteRule ^(.*)$ https://www.yourdomain.com/folder/$1 [R,L]

HTTP 自动跳转 HTTPS(Nginx)

建议在 Nginx 虚拟主机配置文件对应的网站配置段中增加跳转项 if...

server
{
listen 80;
server_name www.websoft9.com;
index readme.html index.html index.htm;
root /data/nas/www.websoft9.com;
error_log /var/log/nginx/www.websoft9.com-error.log crit;
access_log /var/log/nginx/www.websoft9.com-access.log;
include conf.d/extra/*.conf;

# HTTP to HTTPS
if ($scheme = http) {
return 301 https://$host$request_uri;
}

listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/www.websoft9.com/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/www.websoft9.com/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}

中文域名配置 HTTPS

中文域名很特殊,它仅在中国被使用。HTTPS 是不支持中文域名的,但如何设置证书呢?

  1. 中国互联网络信息中心转码。例如:网久软件.com 转码为 xn--3iQsQ211JuqN.com

  2. 域名解析:将中文域名解析直接解析到服务器 IP 地址

  3. 域名绑定:在虚拟主机配置文件中绑定 xn--3iQsQ211JuqN.com

  4. 使用 certbot 命令自动配置HTTPS 或 使用xn--3iQsQ211JuqN.com申请证书后再配置 HTTPS

问题解答

向云平台申请免费证书要注意什么?

  • 免费证书只能用于单个域名,例如: buy.example.com 或 next.buy.example.com,
  • example.com 是通配符域名方式,不能用于申请免费证书
  • 申请证书的时候,请先解析好域名,有些证书会绑定域名对应的 IP 地址,即一旦申请后,IP 地址不能更换,否则证书不可用

Docker 应用如何部署 HTTPS?

我们的方案中,不建议在容器内部设置 HTTPS,而是通过宿主机的 HTTP 服务器(Nginx/Apache等)在端口转发的模式下配置 HTTPS。

IP 地址可以申请 HTTPS 吗?

不可以,且没有任何意义。

Android 无法使用HTTPS,而 iOS 可以?

确保 SSLCertificateChainFile 已设置对应的证书文件

HTTPS 设置成功,仍显示“与此网站建立的连接并非完全安全”?

首选明确一点即您的HTTPS设置是成功的,只是由于网站中存在包含 http访问的静态文件 或 外部链接等,导致浏览器告警您的网站并非完全安全。

Certbot 证书存放在哪里?

Certbot 证书目录:/etc/letsencrypt/live

有哪些 Web Server 可方便支持 HTTPS?

主流的 Web Server 都可以很方便的支持,包括:Apache, Nginx , Caddy