七牛免费SSL证书,配置自定义域名CDN加速
申请七牛 SSL 证书
其实,七牛在很早之前就支持 CDN 使用 https,但是他要求证书的有效期是一年及以上,而我的主站用了 Let’s Encrypt 的免费 SSL 证书,有效期 90 天,自动续签的形式。所以,为了使 CDN 的图片也是 https 的,一直采用了七牛默认的xxx.qnssl.com
域名。
在 11 月,七牛发布了免费 SSL 证书,亚洲诚信的 DV 证书。申请起来也很简单,参见七牛 SSL 证书申请。当然,申请的证书只能用于 CDN 加速。
绑定自定义域名
通过个人面板-证书管理,我申请了域名为static.excaliburhan.com
的 SSL 证书,验证成功后,接下来就是绑定自定义域名了。进入七牛云空间首页,点击对象存储,选择你想要使用 https 的 bucket,在融合 CDN 加速域名自定义域名点击右边,进行添加自定义域名。
在通信协议选项中选择 HTTPS,可以选择或者手动填写证书。如果申请成功,下拉就可以看到我们的证书了。选中后,七牛会自动填写证书内容和私钥。这时,不要急着点击完成,将证书内容复制保存为 certificate.crt(名字可以自行改,后缀需要保持一下,下同),将私钥内容复制保存为 certificate.key,为后面配置做准备。这么做的原因主要是,我不知道怎么去下载证书内容和私钥,所以就采用这种比较原始的方法了。如果你知道的话,请告诉我。
最后,填完所有内容之后,点击创建即可。这时,添加的域名应该还处于审核状态,需要你添加 CNAME,按照要求填写 CNAME 之后,进入 nginx 设置环节。
nginx 设置
由于我的主站使用的 Let’s Encrypt 证书,并且没有进行泛域名的配置,实际上 Let’s Encrypt 也暂时不支持。那么,对static.excaliburhan.com
进行设置。
首先,我们需要把保存的 certificate.crt 和 certificate.key 传到服务器的相应目录,我这的目录是/etc/nginx/certs
。nginx 简单配置如下。
1 | server { |
重启 nginx,将七牛 CDN 的域名换成自定义的域名,发现 Chrome 报错:隐私设置错误。研究发现,主要是我 nginx 主站设置了 HSTS 和 HPKP,并且都设置了 includeSubDomains。而我的主站使用的 SSL 证书和七牛的 SSL 证书并不是一个厂商,所以,请求被当成了劫持攻击了!
1 | add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload"; |
解决方法就是去掉 includeSubDomains。
1 | add_header Strict-Transport-Security "max-age=31536000"; |
而且我还去掉了 preload,原因有二,一是 preload list 申请必须包含 includeSubDomains;二是个人网站申请 Chrome 的 preload list 基本无效。
除此之外,还要添加七牛 SSL 证书的 CA 的 Public Key 指纹,七牛的 SSL 证书是 TrustAsia DV SSL CA - G5,指纹是IiSbZ4pMDEyXvtl7Lg8K3FNmJcTAhKUTrB2FQOaAO/s=
。当然你也可以采用根证书 VeriSign Class 3 Public Primary Certification 的指纹:JbQbUG5JMJUoI6brnx0x3vZF6jilxsapbXGVfjhN8Fg=
。不推荐使用站点证书生成的指纹。
添加完毕后,使用service nginx restart
重启 nginx 即可。
后话
你也看到了,我的 Public-Key-Pins 设置了大概一周时间的 max-age,所以一周内访问过我的网站,很有可能出现static.excaliburhan.com
的静态资源加载不出来的情况。这时候,如果是 Chrome,你可以在chrome://net-internals/#hsts
中,手动 delete domain:excaliburhan.com。
为了证明现在的静态资源是使用自定义域名的,放张图。