<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Nginx配置Https零基礎(chǔ)教程

          共 5445字,需瀏覽 11分鐘

           ·

          2020-03-03 23:23



          (給前端大學加星標,提升前端技能.

          作者:賣好車大前端團隊

          https://juejin.im/post/5e44a2aa6fb9a07c9f3fd170

          c30f186bda459e7ff177bd3748f96249.webp

          Nginx配置https零基礎(chǔ)教程


          安裝 nginx


          有可能你當前已經(jīng)通過?apt-get?yum?等命令安裝了,但是可能不支持 https http2 ipv6 等功能。

          查看當前版本配置

          我們可以通過?nginx -V?命令來查看版本以及支持的配置。


          8c90cb2ca2df072f678c44da47f09f35.webp


          下面這以 ubuntu 為例,卸載安裝 nginx


          卸載

          # 移除 nginx$ apt-get --purge remove nginx
          # 查詢 nginx 依賴的包,會列出來$ dpkg --get-selections|grep nginx
          # 移除上面列出的包,例如 nginx-common$ apt-get --purge remove nginx-common
          # 也可以執(zhí)行 autoremove ,會自動刪除不需要的包$ apt-get autoremove
          # 查詢 nginx 相關(guān)的文件,刪掉就可以了$ sudo find / -name nginx*

          安裝

          安裝依賴庫
          # gcc g++apt-get install build-essentialapt-get install libtool
          # pcresudo apt-get install libpcre3 libpcre3-dev
          # zlibapt-get install zlib1g-dev
          # sslapt-get install opensslapt-get install libssl-dev

          安裝 nginx

          到 nginx download 上找到最新的nginx 版本

          # 下載$ wget https://nginx.org/download/nginx-1.17.8.tar.gz# 解壓$ tar -zxvf nginx-1.17.8.tar.gz# 進入目錄$ cd nginx-1.17.8# 配置,這里可能會報錯,缺少啥就去安裝啥$ ./configure --prefix=/usr/local/nginx \--with-http_gzip_static_module \--with-http_v2_module \--with-pcre \--with-http_ssl_module
          # 編譯,這里可能會報錯,缺少啥就去安裝啥
          $ make


          # 安裝
          $?make?install
          # 通過軟連接,這樣就可以直接使用 nginx 執(zhí)行

          sudo ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx

          SSL 證書


          SSL 證書通常需要購買,也有免費的,通過第三方 SSL 證書機構(gòu)頒發(fā)。你也可以在云服務商上購買,但是一般免費的 ssl 證書只能支持單個域名。

          這里推薦 Let’s Encrypt 機構(gòu),然后使用 acme.sh 從 letsencrypt 生成免費的證書,且可以生成泛域名證書。

          參考 acme.sh 中文 wiki 、使用 acme.sh 部署 Let's Encrypt 通過阿里云 DNS 驗證方式實現(xiàn)泛域名 HTTPS

          上面的兩篇文章講的很詳細了,不再贅述。


          PS:

          • 建議使用 DNS 驗證

          • --dns dns_ali??是根據(jù)不同服務商來的,dns_ali?就是指阿里云。其他服務商的參考 How to use DNS API 。

          • 證書生成后,默認在?~/.acme.sh/?目錄下,這里的文件是內(nèi)部使用的,需要使用?--installcert?命令指定到目標位置

          這里將證書放到了 nginx 的 conf 目錄下。.../conf/ssl/...

          配置 http

          http 基礎(chǔ)配置

          http 的配置很簡單,配置如下,我們先讓網(wǎng)站可以訪問起來。

          server {    listen  80;    server_name     wangsijie.top www.wangsijie.top;
          location / { root /var/www/main; index index.html; }}

          使用?http://訪問,就會如下顯示



          30b0ef934198d5324353418be7d872d7.webp



          配置 https

          Https 基礎(chǔ)配置

          server {    listen                  443 ssl;    server_name             wangsijie.top www.wangsijie.top;    # 證書文件,這里使用了 fullchain.cer 通過 acme.sh 生成的泛域名證書    ssl_certificate         ssl/fullchain.cer;    # 私鑰文件    ssl_certificate_key     ssl/wangsijie.top.key;
          location / { root /var/www/main; index index.html; }}
          重啟后,以 https:// 開頭訪問你的網(wǎng)站,就會發(fā)現(xiàn)




          5c13bb6e9503e8567ebd6892c7af325d.webp728dc4cccf0a246950184a50d0fe008d.webp



          修改 http 配置

          但是用?http://?訪問,仍舊顯示連接不安全,我們需要修改配置,當訪問 http 時會重定向到 https 如下

          server {    listen  80;    server_name     wangsijie.top www.wangsijie.top;
          return 301 https://$server_name$request_uri;}

          這時再用?http://?訪問,就會重定向到?https://

          PS:

          網(wǎng)上也有許多使用?rewrite?來重定向,但是?return?指令簡單高效,建議盡量使用?return

          完整配置

          server {    listen  80;    server_name     wangsijie.top www.wangsijie.top;
          return 301 https://$server_name$request_uri;}server { listen 443 ssl; server_name wangsijie.top www.wangsijie.top; ssl_certificate ssl/fullchain.cer; ssl_certificate_key ssl/wangsijie.top.key;
          location / { root /var/www/main; index index.html; }}

          混合配置

          server {    listen          80;    listen                  443 ssl;    server_name             wangsijie.top www.wangsijie.top;    ssl_certificate         ssl/fullchain.cer;    ssl_certificate_key     ssl/wangsijie.top.key;
          location / { root /var/www/main; index index.html; }}

          https 安全


          加密套件

          https 默認采用 SHA-1 算法,非常脆弱。我們可以使用迪菲-赫爾曼密鑰交換。

          我們在?/conf/ssl?目錄下生成?dhparam.pem?文件

          openssl dhparam -out dhparam.pem 2048


          下面的指令?ssl_protocols?和?ssl_ciphers?是用來限制連接只包含 SSL/TLS 的加強版本和算法。

          # 優(yōu)先采取服務器算法ssl_prefer_server_ciphers on;# 使用 DH 文件ssl_dhparam       ssl/dhparam.pem;# 協(xié)議版本ssl_protocols           TLSv1 TLSv1.1 TLSv1.2;# 定義算法ssl_ciphers      EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;復制代碼安全的響應頭# 啟用 HSTS 。允許 https 網(wǎng)站要求瀏覽器總是通過 https 來訪問add_header Strict-Transport-Security "max-age=31536000; includeSubDomains;preload" always;# 減少點擊劫持add_header X-Frame-Options DENY;# 禁止服務器自動解析資源類型add_header X-Content-Type-Options nosniff;# 防XSS攻擊add_header X-Xss-Protection 1;復制代碼服務器優(yōu)化# 配置共享會話緩存大小ssl_session_cache   shared:SSL:10m;# 配置會話超時時間ssl_session_timeout 10m;復制代碼http2 配置http2 配置很簡單,只要后面增加 http2。下面 [::]: 表示 ipv6 的配置,不需要可以不加那一行l(wèi)isten  80;listen  [::]:80;listen  443 ssl http2;listen  [::]:443 ssl http2;

          重啟 nginx 后,你可以在這個網(wǎng)站上 tools.keycdn.com/http2-test 測試http2有沒有配置成功。


          3c0aa774a3abf7b05845182b3e746998.webp



          最后

          完整配置

          server {    listen                  80;    listen                  [::]:80;    listen                  443 ssl http2;    listen                  [::]:443 ssl http2;    server_name             wangsijie.top www.wangsijie.top;
          ssl_certificate ssl/fullchain.cer; ssl_certificate_key ssl/wangsijie.top.key;
          ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m;
          ssl_prefer_server_ciphers on; ssl_dhparam ssl/dhparam.pem; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
          add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always; add_header X-Frame-Options DENY; add_header X-Content-Type-Options nosniff; add_header X-Xss-Protection 1;
          location / { root /var/www/main; index index.html; }}

          配置文件優(yōu)化

          為了讓更多的二級域名支持上面的功能,每個 server 都這么寫太過于繁瑣。

          可以將 listen 443 、ssl、add_header 相關(guān)的單獨寫在一個文件上,然后使用?inculde?指令。

          如下:其他的配置都放在了conf.d/https-base.conf

          server {    listen                  8099;    listen                  [::]:8099;    server_name             test.wangsijie.top;
          include conf.d/https-base.conf;
          location / { root /var/www/test; index index.html; }
          }

          分享前端好文,點亮?在看?dd37af76600edefc7a16275353b25ab4.webp

          瀏覽 58
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  婷婷撸一撸 | 亚洲涩网 | 亚洲无码电影在线观看 | 父女乱情沈娜娜 | 久久久1AV一二三区 |