Flask(補充內容)配置SSL 證書 實現 HTTPS 服務

沒有加密的http服務,就像在裸泳,鉆到水里便將你看個精光。數據在互聯網上傳輸時,如果未經加密,隨時可能被抓包軟件抓住,里面的cookie、用戶名、密碼什么的,它會看得一清二楚,所以,只要你的項目上網,就必須加載ssl證書,它的重要性風云以前的博文有詳細介紹,這里不再贅述。實現https服務,風云在flask系列博文有關于flask項目的安全與部署,但是部署ssl證書介紹得比較籠統,今天補充一篇,在 Flask 中配置 SSL 證書并實現 HTTPS 服務,步驟如下:

步驟 1:獲取 SSL 證書

首先,您需要獲得一個 SSL 證書。您可以選擇購買一個商用證書,也可以使用免費證書提供商,如 Let's Encrypt。這里我們會使用 自簽名證書?來做演示。

1.1 創建自簽名 SSL 證書(適用于測試環境)

可以通過 OpenSSL 創建一個自簽名證書,適合本地開發和測試。

命令:

openssl req -x509 -newkey rsa:4096 -keyout ssl.key -out ssl.crt -days 365

-newkey rsa:4096:生成 4096 位的 RSA 密鑰。

-keyout ssl.key:指定私鑰的保存文件。

-out ssl.crt:指定證書的保存文件。

-days 365:設置證書的有效期為 365 天。

生成的 ssl.key?為私鑰,ssl.crt?為公鑰證書。

看到生成的兩個文件:ssl.crt、ssl.key 則表示成功。當然,此證書為自簽名證書,只適合于測試環境,如果上生產環境,還需專有數字證書,可以上阿里云等申請時長為3個月的免費證書。

步驟 2:在 Flask 中配置 SSL 證書

Flask 的開發服務器支持通過 ssl_context?配置 SSL 證書。您只需在 app.run()?中設置相應的參數。

2.1 配置 Flask 啟動 SSL 服務

首先,確保你已經生成了 SSL 證書文件和私鑰文件(如 ssl.crt?和 ssl.key)。

然后,修改 Flask 應用啟動代碼,使其支持 HTTPS。

from?flask import?Flaskapp = Flask(__name__)@app.route('/')
def?hello():return?"Hello, SSL Flask!"if?__name__ == '__main__':# 指定 SSL 證書和私鑰文件app.run(ssl_context=('ssl.crt', 'ssl.key'), host='0.0.0.0', port=443, debug=True)

解釋:

ssl_context=('ssl.crt', 'ssl.key'):通過此參數指定證書文件和私鑰文件。

host='0.0.0.0':監聽所有的 IP 地址。

port=443:使用 HTTPS 默認端口 443。

啟動應用后,訪問 https://localhost/?即可通過 HTTPS 訪問您的 Flask 應用。

步驟 3:配置 Nginx 作為反向代理

在生產環境中,建議通過 Nginx 作為反向代理將 HTTP 請求轉發到 Flask 后端,提升性能和安全性。

3.1 安裝 Nginx

sudo apt update

sudo apt install nginx

3.2 配置 Nginx 反向代理

編輯 Nginx 配置文件,配置 HTTPS 和反向代理。

sudo nano /etc/nginx/sites-available/yourapp

配置文件內容如下:

server?{listen?443?ssl;server_name?example.com;ssl_certificate?/path/to/ssl.crt;ssl_certificate_key?/path/to/ssl.key;location?/ {proxy_pass?http://127.0.0.1:5000; ?# Flask 應用監聽的端口proxy_set_header?Host $host;proxy_set_header?X-Real-IP $remote_addr;proxy_set_header?X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header?X-Forwarded-Proto $scheme;}
}server?{listen?80;server_name?example.com;return?301?https://$host$request_uri; ?# 將所有 http 請求重定向到 https
}

解釋:

listen 443 ssl;:Nginx 在端口 443 上監聽 HTTPS 請求。

ssl_certificate?和 ssl_certificate_key:指定 SSL 證書和私鑰路徑。

proxy_pass:將請求代理到 Flask 后端應用(假設 Flask 應用運行在 5000 端口)。

return 301 https://$host$request_uri;:將所有的 HTTP 請求重定向到 HTTPS。

3.3 啟動 Nginx

創建符號鏈接以啟用配置,并重啟 Nginx 服務:

sudo ln?-s /etc/nginx/sites-available/yourapp /etc/nginx/sites-enabled/

sudo systemctl restart nginx

步驟 4:使用 Let's Encrypt 配置 HTTPS(生產環境)

對于生產環境,推薦使用 Let's Encrypt?免費的 SSL 證書。

4.1 安裝 Certbot

首先,安裝 Certbot 以便從 Let's Encrypt 獲取 SSL 證書。

sudo apt install certbot python3-certbot-nginx

4.2 獲取證書

使用 Certbot 自動獲取并配置 SSL 證書:

sudo certbot --nginx -d example.com

Certbot 會自動為您生成證書并配置 Nginx。

4.3 自動續期

Let’s Encrypt 的證書有效期為 90 天,因此需要設置自動續期。您可以通過以下命令測試自動續期:

sudo certbot renew --dry-run

如果測試成功,Certbot 將在每次系統更新時自動續期證書。

總結

通過以下步驟,您可以在 Flask 應用中實現 HTTPS 服務:

獲取 SSL 證書:可以使用自簽名證書或者通過 Let's Encrypt 獲取免費證書。

配置 Flask 啟動 HTTPS 服務:使用 Flask 內置的 ssl_context?參數啟動 HTTPS 服務。

配置 Nginx 反向代理:在生產環境中,使用 Nginx 來管理 HTTPS 連接,提升性能。

Let's Encrypt 配置:對于生產環境,使用 Certbot 獲取免費的 SSL 證書并配置自動續期。

通過這些步驟,您可以成功在 Flask 應用中實現 HTTPS 服務,確保您的應用安全可靠。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/77159.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/77159.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/77159.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

云服務器CVM標準型S5實例性能測評——2025騰訊云

騰訊云服務器CVM標準型S5實例具有穩定的計算性能,CPU采用采用 Intel Xeon Cascade Lake 或者 Intel Xeon Cooper Lake 處理器,主頻2.5GHz,睿頻3.1GHz,CPU內存配置2核2G、2核4G、4核8G、8核16G等配置,公網帶寬可選1M、3…

什么是智算中心

智算中心是一種專門為智能計算提供強大算力支持的基礎設施,以下是關于它的詳細介紹: 定義與功能 智算中心是基于強大的計算能力,特別是針對人工智能算法進行優化的計算中心。它集成了大量的高性能計算設備,如 GPU 集群、FPGA 陣…

注意力機制是如何實現的

注意力機制的實現可以分解為幾個核心步驟,其本質是通過動態計算權重,決定不同位置信息的重要性,再對信息進行加權融合。以下從數學原理、代碼實現到直觀解釋逐步展開: 一、核心實現步驟 以最常見的**點積注意力(Dot-P…

【裁員感想】

裁員感想 今天忽然感覺很emo 因為知道公司要裁員 年中百分之10 年末百分十10 我知道這個百分20會打到自己 所以還挺不開心的 我就想起 我的一個親戚當了大學老師 我覺得真的挺好的 又有寒暑假 又不是很累 薪資也不低 又是編制 同時也覺得自己很失敗 因為對自己互聯網的工作又…

從信號處理角度理解圖像處理的濾波函數

目錄 1、預備知識 1.1 什么是LTI系統? 1.1.1 首先來看什么是線性系統,前提我們要了解什么是齊次性和疊加性。

目標檢測概述

為什么基于卷積網絡的目標檢測模型在預測后要使用非極大值抑制 基于卷積網絡的目標檢測模型可能會在目標的相鄰區域生成多個相互重疊框,每個框的預測結果都是同一個目標,引起同一目標的重復檢測。造成這一現象的原因主要有兩個, 基于卷積網絡…

【JAVA】在idea新加artifact時,點擊Build-Build Artifacts時,新加的artifact不能選中

首先保證添加artifact無問題,比如依賴都正確、無重復命令的情況等 辦法 一 File > Invalidate Caches / Restart。 重啟IDEA后,重新檢查Artifact是否可選 辦法 二 打開 Project Structure(CtrlShiftAltS)。 進入 Artifacts 選…

Paramiko 使用教程

目錄 簡介安裝 Paramiko連接到遠程服務器執行遠程命令文件傳輸示例 簡介 Paramiko 是一個基于 Python 的 SSH 客戶端庫,它提供了在網絡上安全傳輸文件和執行遠程命令的功能。本教程將介紹 Paramiko 的基本用法,包括連接到遠程服務器、執行命令、文件傳輸…

《TCP/IP網絡編程》學習筆記 | Chapter 24:制作 HTTP 服務器端

《TCP/IP網絡編程》學習筆記 | Chapter 24:制作 HTTP 服務器端 《TCP/IP網絡編程》學習筆記 | Chapter 24:制作 HTTP 服務器端HTTP 概要理解 Web 服務器端無狀態的 Stateless 協議請求消息(Request Message)的結構響應消息&#x…

【Quest開發】在虛擬世界設置具有遮擋關系的透視窗口

軟件:Unity 2022.3.51f1c1、vscode、Meta XR All in One SDK V72 硬件:Meta Quest3 僅針對urp管線 參考了YY老師這篇,可以先看他的再看這個可能更好理解一些:Unity Meta Quest MR 開發(七):使…

GPU 招投標全流程分析與總結

GPU 招投標全流程分析與總結 招投標流程概述 以下是通過代理商采購Nvidia H20-GPU 141G的招投標全流程分析: #mermaid-svg-hMPPfkCpGj8GKXfV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-hMPPfkCpGj8GKXfV .er…

[C++] STL中的向量容器<vector>附加練習

目錄 講在前面(必看)八卦陣題目描述輸入格式輸出格式輸入輸出樣例數據范圍AC代碼及要點 決賽應援題目描述輸入格式輸出格式輸入輸出樣例數據范圍AC代碼及要點 講在前面(必看) 本篇為練習篇, vector講解篇在這里. 菜鳥食用前請做好心理準備(你懂的) 八卦陣 題目描述 n 名同學…

基于SpringBoot+Vue3實現的寵物領養管理平臺功能一

一、前言介紹: 1.1 項目摘要 隨著社會經濟的發展和人們生活水平的提高,越來越多的人開始關注并參與到寵物領養中。寵物已經成為許多家庭的重要成員,人們對于寵物的關愛和照顧也日益增加。然而,傳統的寵物領養流程存在諸多不便&a…

parameter和localparam的區別(verilog中)

在Verilog中,parameter 和 localparam 都用于定義常量,但是它們之間有一些重要的區 作用范圍: parameter:可以在模塊外部被修改或重定義。它可以被作為模塊的參數傳遞給其他模塊,因此具有較廣泛的作用范圍,…

鴻蒙API15 “一多開發”適配:解鎖黃金三角法則,開啟高效開發新旅程

一、引言 在萬物互聯的時代浪潮中,鴻蒙操作系統以其獨特的 “一多開發” 理念,為開發者打開了一扇通往全場景應用開發的新大門。“一多開發”,即一次開發,多端部署 ,旨在讓開發者通過一套代碼工程,就能高效…

Linux中docker容器拉取鏡像失敗解決方案

查看 /etc/systemd/system/docker.service.d/http-proxy.conf 文件(沒有則新建),查看自定義 Docker 服務的代理設置 輸入內容 [Service] Environment"HTTP_PROXYsocks5://10.211.13.214:7890" Environment"HTTPS_PROXYsocks…

半導體設備通信標準—secsgem v0.3.0版本使用說明文檔(2)之GEM(SEMI 30)

文章目錄 1、處理器1.1、事件 2、GEM 合規性2.1、狀態模型2.2、 設備加工狀態2.3、 文檔2.4、 控制 (作員啟動)2.5、 動態事件報告配置2.6、 跟蹤數據收集2.7、 報警管理2.8、 遠程控制2.9、 設備常量2.10、 工藝配方管理2.11、 物料移動2.12、 設備終端…

每日算法-鏈表(23.合并k個升序鏈表、25.k個一組翻轉鏈表)

一.合并k個升序鏈表 1.1題目描述 1.2題解思路 解法一:小根堆 我們可以先定義一個小根堆,將k個指針的頭結點如堆,每次取堆頂元素尾插到newhead中,然后再pop(),接著push堆頂原來堆頂元素的下一個節點 重點分析&#…

Java性能剖析工具箱

1. 基礎知識 1.1 Java性能調優概述 1.1.1 性能調優的重要性 性能調優是提升系統效率、降低成本和增強用戶體驗的關鍵步驟。通過優化,可以減少響應時間、降低資源消耗并提高系統的穩定性和可擴展性。 1.1.2 性能問題的常見表現 高CPU使用率:可能由熱點方法或線程阻塞引起。…

如何使用SpringApplicationRunListener在Spring Boot 應用的不同生命周期階段插入自定義邏輯

目錄 一、引言二、核心方法概述三、加載機制四、使用場景五、擴展 - 如何在測試的不同階段插入邏輯5.1 TestExecutionListener & AbstractTestExecutionListener5.1.1 主要功能5.1.2 生命周期方法 5.2 如何集成TestExecutionListener5.3 總結 一、引言 SpringApplicationR…