前言
访问个人网站,偶尔会跳出广告,看来网站被运营商劫持了。为了避免这种情况,小编决定对网站进行https加密。早在2015年,美国政府就要求所有联邦政府网站使用https加密连接,这次小编也算是赶上了国际潮流的尾巴。
https简介
HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。 它是一个URI scheme(抽象标识符体系),句法类同http:体系。用于安全的HTTP数据传输。https:URL表明它使用了HTTP,但HTTPS存在不同于HTTP的默认端口及一个加密/身份验证层(在HTTP与TCP之间)。这个系统的最初研发由网景公司(Netscape)进行,并内置于其浏览器Netscape Navigator中,提供了身份验证与加密通讯方法。现在它被广泛用于万维网上安全敏感的通讯,例如交易支付方面。
配置原理
https是在http下加入ssl层,那么,怎么加入呢?很简单,在nginx、apache等web服务器中加入ssl安全证书的配置即可。
ssl证书申请
很多网站都提供免费的ssl证书,收集整理如下:
- Let’s Encrypt官网和Certbot官网,用法参考《使用Let's Encrypt加密你的小站》。
- 阿里云免费SSL证书,保护类型选择1个域名,选择品牌选择Symantec,即可看到免费型DV SSL。
- 腾讯云免费SSL证书
- 七牛免费SSL证书
推荐使用阿里云、腾讯云和七牛,注册登录,根据提示填写信息,不久就可以拿到证书。
解压www.voidking.com.zip
,可以得到下列文件:
www.voidking.com
│ www.voidking.com.csr
│
├─Apache
│ 1_root_bundle.crt
│ 2_www.voidking.com.crt
│ 3_www.voidking.com.key
│
├─IIS
│ keystorePass.txt
│ www.voidking.com.pfx
│
├─Nginx
│ 1_www.voidking.com_bundle.crt
│ 2_www.voidking.com.key
│
└─Tomcat
keystorePass.txt
www.voidking.com.jks
思路
gitlab
github和coding,都不支持上传ssl证书。但是,gitlab支持啊!最简单的思路就是,把网站迁到gitlab上。
按照这个思路,参考《利用gitlab pages和hexo搭建一个个人博客》和《零成本打造安全博客的简单办法》。
1、打开gitlab的项目,Settings,Pages,New Domain,即可进入域名配置页面。
2、Domain填入www.voidking.com
,Certificate (PEM)填入1_www.voidking.com_bundle.crt
中的内容,Key (PEM)填入2_www.voidking.com.key
中的内容。
反向代理
反向代理是普遍思路,无论我们的真实服务器在github、coding还是gitlab,都可以使用反向代理的方式完成https加密连接。前提是你有一个公网服务器,上面安装了nginx。
用户访问域名;域名解析到公网IP,访问到nginx;nginx反向代理到coding等真实服务器,通过http方式拿到页面;nginx拿到页面后进行ssl加密,然后返回给用户加密后的页面。
Cloudflare
Cloudflare是一家CDN提供商,它提供了免费的https服务(但不是应用SSL证书)。实现模式就是,用户到CDN服务器的连接为https,而CDN服务器到真实服务器的连接为http。也就是说,在CDN服务器那里加上反向代理。没错,又是反向代理,只不过这次的代理服务器归属于Cloudflare,不是我们自己的。
这种方式,好处是你不需要拥有自己的公网服务器,坏处是你必须把域名的dns服务器换成cloudflare。
具体设置步骤参考《让个人域名下GithubPage完美支持https》。
详细步骤
小编决定选用最通用的方式,通过nginx反向代理来实现https访问(假设已经申请好了ssl证书)。
修改域名解析
原来的域名解析位CNAME记录,指向pages.coding.me,现在修改为A记录,指向公网IP。
上传证书
1、服务器上,创建目录ssl
mkdir /etc/nginx/ssl
2、使用xftp上传 www.voidking.com/Nginx 文件夹中的1_www.voidking.com_bundle.crt和2_www.voidking.com.key到ssl目录。
配置nginx
配置nginx,参考《Nginx开启SSL与重定向优化》
1、coding pages配置不变,依然绑定www.voidking.com域名。
2、/etc/nginx/conf.d中新建配置文件www.voidking.com.conf,内容如下:
server {
listen 80;
listen 443 ssl;
server_name www.voidking.com;
charset utf-8;
#ssl配置
ssl_certificate /etc/nginx/ssl/1_www.voidking.com_bundle.crt;
ssl_certificate_key /etc/nginx/ssl/2_www.voidking.com.key;
ssl_session_timeout 5m;
ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!ADH:!EXPORT56:RC4+RSA:+MEDIUM;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 1024m;
client_body_buffer_size 128k;
client_body_temp_path /var/data/client_body_temp;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
proxy_temp_path /var/data/proxy_temp;
proxy_pass http://voidking.coding.me;
}
}
3、重启nginx
systemctl restart nginx
4、测试访问
访问 https://www.voidking.com ,已经可以正常访问网址,只不过有些脚本是通过http方式引用的,会提示不安全,等下我们修改了hexo主题就好了。
修改hexo主题
1、访问 https://www.voidking.com ,F12,启用调试模式,查看哪些文件是不安全的。
2、修改hexo主题,把那些不安全的文件全部修改为https引用。
jquery
在hexo/themes/yilia/layout/_partial
中找到head.ejs,修改jquery引用地址为:
mathjax
《Hexo中使用Mathjax的冲突问题》一文中,我们引用mathjax的方式也是http,引用单位是整个主题(所有的页面)。下面我们把引用方式修改为https,引用单位改为单个页面。
1、把hexo/themes/yilia/layout/_partial
中的mathjax.ejs移动到hexo/themes/yilia/layout/_partial/post
。
2、修改mathjax.ejs中的js引用: