av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:4日期:2024-09-08 13:35:08
為什么你的網(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ù)器之間的傳輸文本,就可以直接讀取其中的信息。

為了解決這個隱患和保證數(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ù)器,請確保設(shè)置安全組時已經(jīng)開放了443端口。

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

一共分三步:

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

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

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

第一步:購買下載SSL證書

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

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

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

第二步:修改Nginx配置信息

在生產(chǎn)環(huán)境中部署Django時我們一般以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ù)器上任何一個指定目錄,但通常做法是將其上傳到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請求永久地重定向至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ù)提供更高級別的保護(hù)。這個設(shè)置也是django cookiecutter推薦的在生產(chǎn)環(huán)境中的默認(rèn)配置。

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

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

MIDDLEWARE = [ ’django.middleware.security.SecurityMiddleware’,]小結(jié)

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

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

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 欧美激情综合 | 99热在线免费观看 | 亚洲日本中文字幕 | 成年人免费在线观看 | 超碰99在线 | 四虎视频 | 国产精品欧美精品 | 国产a久久麻豆入口 | 日韩大片在线观看 | 懂色av一区二区夜夜嗨 | 一色桃子av | 国产成人av一区二区三区在线观看 | 日韩怡红院 | 日韩欧美视频 | 成人玩具h视频 | 夜夜嗨av一区二区三区网页 | 国产精品久久久精品 | 国产精品成人免费精品自在线观看 | 天天射夜夜操 | 日皮视频免费看 | 欧美精品网 | 亚洲一级二级三级 | 日韩在线视频播放 | 国产日韩在线视频 | 日本加勒比在线观看 | 一本一道久久a久久精品蜜桃 | 久久久精品免费 | 久草视频观看 | 亚洲午夜在线 | 亚洲精品播放 | 国产午夜视频 | 成人婷婷 | 中文字幕在线看 | 成人毛片网站 | 日韩免费一区 | 久久草av | 国产香蕉视频在线观看 | 国产网站在线 | 日本精品视频 | 国产欧美一区二区三区视频在线观看 | 欧美精品一级片 |