在上篇文章中,介绍了如何安装typecho博客系统,默认是没有启用https访问的,这篇文章介绍如何 在IIS中开启 https访问。
开启https访问需要两个步骤:
1、申请 一个ssl证书,我这里以阿里云上面的申请流程为例。其它云服务器应该也是差不多的。
2、安装IIS Rewrite模块,并添加http跳转到https的重写规则。
申请证书:
打开阿里云控制台,打开数字证书管理服务。选择SSL证书,在免费证书下找到创建证书。
data:image/s3,"s3://crabby-images/e2f8b/e2f8be39da0a44fa7aab40064410a6f35134995a" alt=""
data:image/s3,"s3://crabby-images/42e1e/42e1e5368d739558a01f4619729c8c5ea9aa9599" alt=""
创建后,可以在下面的列表看到一个待申请 的证书。点击证书申请
data:image/s3,"s3://crabby-images/57d06/57d06a4ff77be76f2a7b7944566795b1cd237a80" alt=""
填写相关信息,
域名这里填写你的域名,类似 www.xxx.com www.xxx.cn这样。
域名验证方式选择自动DNS验证
CSR生成方式选自动
注意:免费证书只能绑定一个域名,所以这里不能用通配符 * ,如 *.server.com这种是不行的。
data:image/s3,"s3://crabby-images/edc67/edc67936eaacb8fed00892ebb13fb479eec0bc09" alt=""
单击提交申请
需要进行DNS验证,需要我们在域名解析里加上如下的解析记录。
data:image/s3,"s3://crabby-images/e5360/e53606c93a4b2e05f47d64b0a4b9f9f355b02c8b" alt=""
新开一个浏览器标签,切换到域名控制台,找到自己的域名,单击解析
data:image/s3,"s3://crabby-images/52451/52451c1700b66c3ad0c886b3d8b03e6dbc7203ce" alt=""
添加一条TXT解析记录,内容就是申请 证书时验证DNS需要添加的记录内容,如下:
data:image/s3,"s3://crabby-images/ea578/ea578fccd18533086dc4a7bc50c5f63cc3037dbb" alt=""
增加后,我们再回到证书申请 那个界面,单击验证,验证成功。
data:image/s3,"s3://crabby-images/7fcea/7fcea3a8c4597e7f02d1813a0a17ddcbc5f79467" alt=""
等待几分钟,可以看到证书已经签发,然后点击 下载
data:image/s3,"s3://crabby-images/fa5bc/fa5bca47acf249617117cbf1525b97e2af024341" alt=""
选择IIS
data:image/s3,"s3://crabby-images/596a5/596a5ad4abc4b471fab5cd13942f8045e43939bb" alt=""
下载证书并解压到任意位置,可以看到下面两个文件
data:image/s3,"s3://crabby-images/10eb8/10eb8fd3d2a65d206b72e9727ad688465716f794" alt=""
布署证书到IIS
运行输入 inetmgr,打开IIS控制台,选择服务器,再选择服务器证书
data:image/s3,"s3://crabby-images/0a82c/0a82c3d7182f781471b41a596a7cd69d520ad0f2" alt=""
单击导入,证书文件选择前面解压 出来的.pfx文件,密码就是pfx-password.txt中的文本,证书存储选择Web宿主
data:image/s3,"s3://crabby-images/3270b/3270b7214fcde4ce7de600e395ed5acd9fe3dd55" alt=""
导入成功后,可以在证书列表里看到证书
data:image/s3,"s3://crabby-images/28dde/28dde759e78d3f4ef1011c5c3110d757f51557b6" alt=""
将证书绑定到网站上
打开自己的网站,选择绑定
data:image/s3,"s3://crabby-images/03fa4/03fa42260859a682c08c1577f6ed6d26f10838f3" alt=""
端口填入443,证书选择前面导入的证书。
注意:如果443端口被占用了,如SVN Server之类的。请将其它应用程序占用的端口切换到8443端口,保证在IIS中443端口可用。
data:image/s3,"s3://crabby-images/041b3/041b3bfda49cce1a9e02e051611e5f4f01aa0e16" alt=""
到这里其实已经可以 https 访问网站了,但是存在一个问题,就是需要在输入网址的时候 自己加上 https ,这个操作肯定 是不方便的,所以我们需要自动跳转到https。就是Url Rewrite模块的功劳了。
下载并安装IIS Rewrite模块。
打开URL Rewrite : The Official Microsoft IIS Site,滑到下面 ,选择对应 的版本,我这里选的是Chinese Simplified x64 installer,如果你的系统是32位,就选x86。
data:image/s3,"s3://crabby-images/dde93/dde93caf448e9c8105a1ad6e0b237304994b2fbc" alt=""
下载完成后进行安装,打开IIS控制台,可以看到 Url重写模块
data:image/s3,"s3://crabby-images/a4459/a4459f702811fae96c6d10bc43b0467dd6cf18dc" alt=""
选择自己的网站,打开URL重写,添加规则 ,选择空白规则 (觉得对照图片添加麻烦的,可以直接使用后面的参数添加到web.config中)。
填入如下 的内容
data:image/s3,"s3://crabby-images/7ed36/7ed36290d5689c96d82e17a9c14fef346d5dbdce" alt=""
添加一个新的条件,如下图所示:
data:image/s3,"s3://crabby-images/ef2bf/ef2bf1c75cacf7893ce9ec1451e4997fc20e68e4" alt=""
操作的参数如下:
data:image/s3,"s3://crabby-images/44994/449944681924ef0487b8b4977bcefb0f2daac622" alt=""
配置完成后,就可以自动跳转到https。
也可以直接复制如下内容到你网站目录下 web.config文件中
1 <?xml version="1.0" encoding="utf-8"?>
8 <configuration>
10 <system.webServer>
11 <rewrite>
12 <rules>
13 <rule name="HTTP To HTTPS" stopProcessing="true">
14 <match url="(.*)" />
15 <conditions>
16 <add input="{HTTPS}" pattern="^OFF$" />
17 </conditions>
18 <action type="Redirect" url="https://{HTTP_HOST}/{R:1}" redirectType="Found" />
19 </rule>
20 </rules>
21 </rewrite>
28 </system.webServer>
39 </configuration>
这样就可以为 typecho博客开启 https 访问了