亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Nginx下將http改為https的操作步驟

 更新時間:2024年08月06日 11:57:10   作者:野生的狒狒  
HTTPS是HTTP協(xié)議的安全版本,通過使用SSL(安全套接層)或TLS(傳輸層安全)協(xié)議加密通信,為數(shù)據(jù)傳輸提供了保密性、完整性和身份認證,本文給大家介紹了Nginx下將http改為https的操作方法,需要的朋友可以參考下

將服務從 HTTP 變?yōu)?nbsp;HTTPS,需要進行 SSL 證書的配置。需要完成一下步驟:

  • 獲取 SSL 證書
  • 安裝 SSL 證書
  • 配置 Nginx 支持 HTTPS
  • 重啟 Nginx
  • HTTP 到 HTTPS 的重定向(可選)

1. 獲取 SSL 證書(自簽名證書)

對于 SSL/TLS 證書,一般來說,它們是基于 域名 進行頒發(fā)的,而不是 IP地址。這是因為 SSL/TLS 證書是用來驗證服務器身份和提供一個安全的連接通道的,它們需要關(guān)聯(lián)到一個被認可的域名以確保服務器的真實性。

如果你沒有 域名,但是你的應用又需要使用 HTTPS,那么以下幾種方式或許可以考慮:

  1. 購買一個域名:
    域名現(xiàn)在相當便宜,你可以購買一個,并將其解析到你的 IP 地址。
  2. 自簽名證書:
    可以創(chuàng)建自己的自簽名證書。但是,用戶的瀏覽器會顯示一個警告,提示他們證書不受信任。這可能不適合面向公眾的應用程序,但對于測試或內(nèi)部使用的服務來說,這是一個可行的選擇。
  3. 使用 CloudFlare
    CloudFlare 是一個內(nèi)容分發(fā)網(wǎng)絡(CDN)和 DNS 提供商,它提供免費的 SSL 證書,即使你沒有域名也可以使用。但是,這需要將你的流量通過他們的網(wǎng)絡,可能并不適合所有應用。

1.1. 安裝 openssl

// 更新 apt-get 下載源節(jié)點
sudo apt-get update
 
// 查看當前 apt-get 下載源節(jié)點里 libssl-dev 可下載安裝的所有版本和默認的最合適的版本
sudo apt-cache policy libssl-dev
 
// 下載并默認安裝 libssl-dev(默認的版本)
sudo apt-get install libssl-dev
 
// 如果要指定安裝某個版本
//sudo apt-get install libssl-dev=版本號

1.2. 自簽名證書

使用 OpenSSL 工具來創(chuàng)建自己的自簽名證書

  1. 生成私鑰
    打開命令行,然后輸入以下命令來生成一個新的 RSA 私鑰:openssl genrsa -out server.key 2048,將在當前目錄下生成一個名為 server.key 的 2048 位私鑰文件。
  2. 生成證書簽名請求(CSR)
    使用此命令生成 CSR(Certificate Signing Request):openssl req -new -key server.key -out server.csr,會提示輸入很多東西,一直按 enter 即可
  3. 生成自簽名證書
    最后,使用以下命令生成自簽名證書:openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt,這將生成一個有效期為一年的自簽名證書 server.crt

1.3. 嘗試在 flask 應用中使用

from flask import Flask
 
 
app = Flask(__name__)
 
 
@app.route("/")
def index():
    return "Hello World"
 
 
if __name__ == "__main__":
    app.run(ssl_context=('server.crt', 'server.key'), host='0.0.0.0', port=8080)
    #app.run(host='0.0.0.0', port=8080)

這樣,F(xiàn)lask 服務器就會在 HTTPS 上運行了。但是,請注意,因為使用的是自簽名證書,所以瀏覽器將警告用戶這個連接不安全(因為證書不是由受信任的證書頒發(fā)機構(gòu)簽署的)。對于公開服務,應該考慮獲得一個由公認的 CA 簽署的證書。

直接在 flask 中使用 ssl 證書的示意圖:

image

image

2. 安裝 SSL 證書

將上面生成的 SSL 證書文件放置到位于 /etc/nginx/ssl/ 目錄中。確保已經(jīng)擁有了服務器私鑰(server.key)和證書文件(server.crt 或 server.crt)。

3. 配置 Nginx 支持 HTTPS

3.1. 打開 Nginx 配置文件

Nginx 的配置文件通常位于 /etc/nginx/ 目錄下,具體取決于你的系統(tǒng)和 Nginx 安裝方式。大部分情況下,站點特定的配置在 /etc/nginx/sites-available/ 中。

3.2. 修改或增加一個server塊

在 /etc/nginx/sites-available/default 配置文件中,將文件中的內(nèi)容全部替換為下面的 server 模塊(或者新建一個使用 SSL 的 server 塊),內(nèi)容如下:

server {
    listen 443 ssl;
    server_name _;
    # server_name your-domain.com;                  # 沒有域名則直接寫一個下劃線即可
 
    ssl_certificate /etc/nginx/ssl/server.crt;      # 修改為證書路徑
    ssl_certificate_key /etc/nginx/ssl/server.key;  # 修改為私鑰路徑
 
    location / {
        proxy_pass http://127.0.0.1:8080;           # 修改為 http 服務地址
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}
  • 替換 your-domain.com 為真實的域名,沒有域名則直接寫一個下劃線(_)即可。
  • listen 443 ssl 告訴 Nginx 在 443 端口上監(jiān)聽 SSL 連接。
  • ssl_certificate 和 ssl_certificate_key 指令分別指向你的證書文件和私鑰文件的實際路徑。

4. 重啟 Nginx

保存并關(guān)閉配置文件,然后運行以下命令來檢查新的配置是否有語法錯誤:

sudo nginx -t

如果這個命令沒有報錯,就可以安全地重啟 Nginx:

sudo systemctl restart nginx

nginx 重啟成功后,將可以在瀏覽器上通過 https 訪問服務器應用了。由于使用的是自簽名證書,用戶的瀏覽器將顯示一個警告,提示他們此證書不受信任。這對于測試和開發(fā)環(huán)境可能沒問題,但是如果計劃在生產(chǎn)環(huán)境中使用 SSL,應該考慮從一個可信的證書頒發(fā)機構(gòu)獲取一個證書。

使用 nginx 作為反向代理后,使用 ssl 證書的示意圖:

image

image

5. HTTP 到 HTTPS 的重定向(可選)

如果希望所有的 HTTP 流量都自動跳轉(zhuǎn)到 HTTPS,可以在 Nginx 配置中添加以下內(nèi)容:

server {
    listen 80;
    server_name your-domain.com;
    return 301 https://$host$request_uri;
}

這段配置會捕獲所有到端口 80(HTTP) 的請求,并將它們重定向到相同地址的 HTTPS 版本。

到此這篇關(guān)于Nginx下將http改為https的操作步驟的文章就介紹到這了,更多相關(guān)Nginx將http改為https內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Nginx 代理轉(zhuǎn)發(fā)阿里云OSS上傳的實現(xiàn)代碼

    Nginx 代理轉(zhuǎn)發(fā)阿里云OSS上傳的實現(xiàn)代碼

    這篇文章主要介紹了Nginx 代理轉(zhuǎn)發(fā)阿里云OSS上傳的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • nginx配置文件不使用緩存的方法

    nginx配置文件不使用緩存的方法

    使用Nginx作為Web緩存服務器,能有效減少數(shù)據(jù)傳輸、節(jié)省網(wǎng)絡流量、加快響應速度、減輕服務器壓力、提高服務端可用性,本文就來介紹一下nginx配置文件不使用緩存的方法,感興趣的可以了解一下
    2024-11-11
  • Nginx 動態(tài)域名解析過程詳解

    Nginx 動態(tài)域名解析過程詳解

    這篇文章主要為大家介紹了Nginx 動態(tài)域名解析過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Nginx訪問日志及錯誤日志參數(shù)說明

    Nginx訪問日志及錯誤日志參數(shù)說明

    這篇文章主要介紹了Nginx訪問日志及錯誤日志參數(shù)說明,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • 一次nginx 504 Gateway Time-out錯誤排查、解決記錄

    一次nginx 504 Gateway Time-out錯誤排查、解決記錄

    這篇文章主要介紹了一次nginx 504 Gateway Time-out錯誤排查、解決記錄,經(jīng)過反復檢查,發(fā)現(xiàn)造成這個問題的原因就是PHP的CURL沒有設置超時時間,解決辦法只要設置超時時間或者修改一下nginx的配置即可解決,需要的朋友可以參考下
    2014-05-05
  • zabbix自定義監(jiān)控nginx狀態(tài)實現(xiàn)過程

    zabbix自定義監(jiān)控nginx狀態(tài)實現(xiàn)過程

    這篇文章主要為大家介紹了zabbix如何自定義監(jiān)控nginx狀態(tài)的實現(xiàn)過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-10-10
  • 結(jié)合 Nginx 將 DoNetCore 部署到 阿里云的安裝配置方法

    結(jié)合 Nginx 將 DoNetCore 部署到 阿里云的安裝配置方法

    這篇文章主要介紹了結(jié)合 Nginx 將 DoNetCore 部署到 阿里云的方法 ,需要的朋友可以參考下
    2018-10-10
  • 一文弄懂Nginx熱升級

    一文弄懂Nginx熱升級

    Nginx熱升級指服務不中斷情況下用新的Nginx二進制文件替換老的Nginx二進制文件,本文就來介紹一下Nginx熱升級,感興趣的可以了解一下
    2024-05-05
  • Nginx?upstream使用教程

    Nginx?upstream使用教程

    本文主要介紹了Nginx?upstream使用教程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • nginx下的代理服務器80端口被封的解決方案

    nginx下的代理服務器80端口被封的解決方案

    這篇文章主要是講:通過nginx下面的代理服務器,實現(xiàn)訪問A地址的時候自動代理到B地址的某個端口,主要用于標題說的某個端口被日.其他東西都正常的情況下,這玩意早上我剛剛測試過,這博客就是個很好的例子.
    2010-06-06

最新評論