如何使用Let's Encrypt免费添加HTTPS

HTTPS需要什么

https基于RSA非对称加密算法,客户端利用公钥加密数据(准确来说是会话key),服务端利用对应的私钥来解密;由于公钥的公开性,无法保证正确性,所以引入了第三方权威机构CA来签发数字证书,数字证书中包含服务端的公钥并和私钥一起保存在服务端,客户端必须从服务端获取数字证书,然后从中取出公钥。然而,CA给站点签发数字证书通常都是收费的, 所以,支持HTTPS的站点,需要三个东西:数字证书、私钥和money。

Let's Encrypt是什么

简单地说,Let's Encrypt是一个免费的CA,背后有Linux基金会和facebook等知名公司撑腰,目的是加速互联网https化进程,所以大家快快用啊!于是,上面说的https需要的东西变成了两个:数字证书、私钥。下面就看看在服务端如何部署这两样东西,让别人访问我们的站点的时候也能显示出高大上的绿框框。

Linux下Nginx服务端部署Https

确保系统安装了python2.7以上的版本,因为Let's Encrypt程序基于python编写。然后安装pip,再通过pip安装virtualenv。

$ python get-pip.py
$ pip install virtualenv

按照Let's Encrypt官方站点的How It Works指导安装Let's Encrypt程序包,安装过程中如果遇到一些错误或者警告,可能是上述的python环境配置不正确,需要优先确保python的配置正确性。官方指南有针对不同web server的plugin,不过这里推荐standalone模式,与web server类型无关,更加通用。

$ git clone https://github.com/letsencrypt/letsencrypt
$ cd letsencrypt
$ ./letsencrypt-auto --help
$ ./letsencrypt-auto certonly --standalone -d yuanwhy.com

生成数字证书的过程中,会要求输入邮箱,同时会检验该域名是否指向当前机器的ip,其实目的就是验证你是不是该域名的真实所有者。成功之后,会出现Congratulations!,在/etc/letsencrypt目录下生成一系列的文件,这里我们只需要关心两个东西:数字证书和私钥文件,在/etc/letsencrypt/archive/yuanwhy.com/目录下,fullchain1.pem就是数字证书,privkey1.pem 就是私钥文件,可以用cat命令查看文件内容,都是标准的Base64编码。修改nginx的配置文件,启用ssl,指明数字证书和私钥文件的地址即可,本站的配置如下

server {
  listen 443 ssl;
  server_name yuanwhy.com;

  ssl_certificate /etc/letsencrypt/archive/yuanwhy.com/fullchain1.pem;
  ssl_certificate_key /etc/letsencrypt/archive/yuanwhy.com/privkey1.pem;

  ssl_session_cache shared:SSL:100m;
  ssl_session_timeout 500m;

  ssl_ciphers HIGH:!aNULL:!MD5;
  ssl_prefer_server_ciphers on;

  location / {
    root /usr/share/nginx/yuanwhy.com/wordpress;
    index index.php;
  }

  location ~ \.php {
    root /usr/share/nginx/yuanwhy.com/wordpress;
    fastcgi_index index.php;
    fastcgi_pass 127.0.0.1:9000;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    include fastcgi_params;
  }
}

如果想强制http协议访问跳转到https,配置nginx转发即可

server {
  listen 80;
  server_name yuanwhy.com;
  return 301 https://$host$request_uri;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容