欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django項(xiàng)目如何獲得SSL證書與配置HTTPS

 更新時(shí)間:2021年04月30日 16:10:32   作者:大江狗  
本文總結(jié)了如何獲得SSL證書并給Django項(xiàng)目配置HTTPS,建議先收藏再閱讀,將來有一天你很可能會(huì)用到它。

為什么你的網(wǎng)站需要支持HTTPS協(xié)議?

簡而言之:HTTPS = HTTP + SSL = 更安全的數(shù)據(jù)傳輸

HTTP協(xié)議簡稱超文本傳輸協(xié)議,它廣泛用于在Web瀏覽器和網(wǎng)站服務(wù)器之間傳遞信息。HTTP協(xié)議的缺點(diǎn)是它以明文方式發(fā)送內(nèi)容(包括用戶密碼),不提供任何方式的數(shù)據(jù)加密。如果攻擊者截取了Web瀏覽器和網(wǎng)站服務(wù)器之間的傳輸文本,就可以直接讀取其中的信息。

為了解決這個(gè)隱患和保證數(shù)據(jù)的傳輸安全,HTTPS協(xié)議(安全套接字層超文本傳輸協(xié)議)誕生了。它在HTTP的基礎(chǔ)上加入了SSL協(xié)議,SSL依靠證書來驗(yàn)證服務(wù)器的身份,并為瀏覽器和服務(wù)器之間的通信數(shù)據(jù)加密。

注意:HTTP協(xié)議默認(rèn)使用的端口是80端口,HTTPS協(xié)議默認(rèn)使用的端口是443端口。如果你使用云服務(wù)器,請(qǐng)確保設(shè)置安全組時(shí)已經(jīng)開放了443端口。

如何在生產(chǎn)環(huán)境中部署Django項(xiàng)目時(shí)配置HTTPS?

一共分三步:

1. 購買下載SSL證書,通常包括一張證書(.cert或.pem)和一個(gè)私有密鑰文件(.key)。

2. 修改Nginx或Apache配置信息,并上傳下載頒發(fā)的SSL證書及key到指定文件夾

3. 修改Django配置文件settings.py

第一步:購買下載SSL證書

SSL證書有很多種, 級(jí)別越高越貴,網(wǎng)上的免費(fèi)午餐并不多。對(duì)于個(gè)人網(wǎng)站使用單域名的DV SSL證書一般就夠了,這種證書阿里云做活動(dòng)期間是可以免費(fèi)申請(qǐng)的。購買SSL證書時(shí)選擇單域名-DV SSL-免費(fèi)版即可,如下圖所示。收費(fèi)版的SSL證書價(jià)格比較便宜的還namecheap。

無論哪個(gè)SSL證書服務(wù)商最后都會(huì)提供證書下載鏈接或直接將證書發(fā)送到你的郵箱,只是流程不同而已。隨后你需要將下載的證書上傳到服務(wù)器指定文件夾,見下一步。

第二步:修改Nginx配置信息

在生產(chǎn)環(huán)境中部署Django時(shí)我們一般以Nginx做反向代理和靜態(tài)文件服務(wù)器,這里簡單說下Nginx的配置信息。Nginx配置文件通常位于/etc/nginx/conf.d目錄下,修改配置文件添加SSL相關(guān)信息。

# /etc/nginx/conf.d目錄下的配置文件
server {
listen 443 ssl; 監(jiān)聽443端口
ssl_certificate /path/to/certificate/your_domain_chain.crt; # 證書地址
ssl_certificate_key /path/to/your_private.key; # 私有密鑰文件地址
server_name your_domain.com www.your_domain.com; # 域名
}

SSL證書和私有密鑰文件可以上傳到服務(wù)器上任何一個(gè)指定目錄,但通常做法是將其上傳到Linux的/usr/share/nginx/ssl目錄下,所以上述配置信息可以簡化為:

# /etc/nginx/conf.d目錄下的配置文件
server {
listen 443 ssl; 監(jiān)聽443端口
ssl_certificate /usr/share/nginx/ssl/your_domain_chain.crt; # 證書地址
ssl_certificate_key /usr/share/nginx/ssl/your_private.key; # 私有密鑰文件地址
server_name your_domain.com www.your_domain.com; # 域名
}

你還可以將所有來自80端口的http請(qǐng)求永久地重定向至https。

server {
listen 80; # 監(jiān)聽80端口
server_name your_domain.com www.your_domain.com;
return 301 https://$server_name$request_uri; # 永久重定向
}

第三步 修改Django的settings.py

當(dāng)你的網(wǎng)站支持https后,你可以在settings.py新增如下安全配置,可以給網(wǎng)站和用戶數(shù)據(jù)提供更高級(jí)別的保護(hù)。這個(gè)設(shè)置也是django cookiecutter推薦的在生產(chǎn)環(huán)境中的默認(rèn)配置。

# SECURITY安全設(shè)置 - 支持http時(shí)建議開啟
SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
SECURE_SSL_REDIRECT = True # 將所有非SSL請(qǐng)求永久重定向到SSL
SESSION_COOKIE_SECURE = True # 僅通過https傳輸cookie
CSRF_COOKIE_SECURE = True # 僅通過https傳輸cookie
SECURE_HSTS_INCLUDE_SUBDOMAINS = True # 嚴(yán)格要求使用https協(xié)議傳輸
SECURE_HSTS_PRELOAD = True # HSTS為
SECURE_HSTS_SECONDS = 60
SECURE_CONTENT_TYPE_NOSNIFF = True # 防止瀏覽器猜測(cè)資產(chǎn)的內(nèi)容類型

注意:Django的SECURE_SSL_REDIRECT = True也可實(shí)現(xiàn)80端口的http請(qǐng)求永久地重定向至https, 與Nginx的301重定向設(shè)置選其一即可。Django以上的幾個(gè)安全設(shè)置均依賴下面這個(gè)SecurityMiddleware中間件。

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
]

小結(jié)

Django項(xiàng)目上線時(shí)配置https非常簡單,僅需3步。你學(xué)會(huì)了嗎?

以上就是Django項(xiàng)目如何獲得SSL證書與配置HTTPS的詳細(xì)內(nèi)容,更多關(guān)于Django 獲得SSL證書與配置HTTPS的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python對(duì)html代碼進(jìn)行escape編碼的方法

    python對(duì)html代碼進(jìn)行escape編碼的方法

    這篇文章主要介紹了python對(duì)html代碼進(jìn)行escape編碼的方法,涉及Python中escape方法的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-05-05
  • django基礎(chǔ)之?dāng)?shù)據(jù)庫操作方法(詳解)

    django基礎(chǔ)之?dāng)?shù)據(jù)庫操作方法(詳解)

    下面小編就為大家?guī)硪黄猟jango基礎(chǔ)之?dāng)?shù)據(jù)庫操作方法(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • Python tkinter和exe打包的方法

    Python tkinter和exe打包的方法

    這篇文章主要介紹了Python tkinter和exe打包的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • python五子棋游戲的設(shè)計(jì)與實(shí)現(xiàn)

    python五子棋游戲的設(shè)計(jì)與實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了python五子棋游戲的設(shè)計(jì)與實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用

    Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用

    HTTP是在網(wǎng)絡(luò)上傳輸HTML的協(xié)議,用于瀏覽器和服務(wù)器的通信,這篇文章主要介紹了Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用,需要的朋友可以參考下
    2022-11-11
  • python實(shí)現(xiàn)處理Excel表格超詳細(xì)系列

    python實(shí)現(xiàn)處理Excel表格超詳細(xì)系列

    這篇文章主要介紹了python實(shí)現(xiàn)處理Excel表格超詳細(xì)系列,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Flask框架利用Echarts實(shí)現(xiàn)繪制圖形

    Flask框架利用Echarts實(shí)現(xiàn)繪制圖形

    echarts是百度推出的一款開源的基于JavaScript的可視化圖表庫,該開發(fā)庫目前發(fā)展非常不錯(cuò),且支持各類圖形的繪制可定制程度高。如下演示案例中,將分別展示運(yùn)用該繪圖庫如何前后端交互繪制(餅狀圖,柱狀圖,折線圖)這三種最基本的圖形,需要的可以參考一下
    2022-10-10
  • tesserocr與pytesseract模塊的使用方法解析

    tesserocr與pytesseract模塊的使用方法解析

    這篇文章主要介紹了tesserocr與pytesseract模塊的使用方法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • TensorFlow2.0矩陣與向量的加減乘實(shí)例

    TensorFlow2.0矩陣與向量的加減乘實(shí)例

    今天小編就為大家分享一篇TensorFlow2.0矩陣與向量的加減乘實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • Python可視化Matplotlib散點(diǎn)圖scatter()用法詳解

    Python可視化Matplotlib散點(diǎn)圖scatter()用法詳解

    這篇文章主要介紹了Python可視化中Matplotlib散點(diǎn)圖scatter()的用法詳解,文中附含詳細(xì)示例代碼,有需要得朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09

最新評(píng)論