Django项目如何获得SSL证书与配置HTTPS


Posted in Python onApril 30, 2021

为什么你的网站需要支持HTTPS协议?

简而言之:HTTPS = HTTP + SSL = 更安全的数据传输

HTTP协议简称超文本传输协议,它广泛用于在Web浏览器和网站服务器之间传递信息。HTTP协议的缺点是它以明文方式发送内容(包括用户密码),不提供任何方式的数据加密。如果攻击者截取了Web浏览器和网站服务器之间的传输文本,就可以直接读取其中的信息。

为了解决这个隐患和保证数据的传输安全,HTTPS协议(安全套接字层超文本传输协议)诞生了。它在HTTP的基础上加入了SSL协议,SSL依靠证书来验证服务器的身份,并为浏览器和服务器之间的通信数据加密。

注意:HTTP协议默认使用的端口是80端口,HTTPS协议默认使用的端口是443端口。如果你使用云服务器,请确保设置安全组时已经开放了443端口。

如何在生产环境中部署Django项目时配置HTTPS?

一共分三步:

1. 购买下载SSL证书,通常包括一张证书(.cert或.pem)和一个私有密钥文件(.key)。

2. 修改Nginx或Apache配置信息,并上传下载颁发的SSL证书及key到指定文件夹

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

第一步:购买下载SSL证书

SSL证书有很多种, 级别越高越贵,网上的免费午餐并不多。对于个人网站使用单域名的DV SSL证书一般就够了,这种证书阿里云做活动期间是可以免费申请的。购买SSL证书时选择单域名-DV SSL-免费版即可,如下图所示。收费版的SSL证书价格比较便宜的还namecheap。

Django项目如何获得SSL证书与配置HTTPS

无论哪个SSL证书服务商最后都会提供证书下载链接或直接将证书发送到你的邮箱,只是流程不同而已。随后你需要将下载的证书上传到服务器指定文件夹,见下一步。

第二步:修改Nginx配置信息

在生产环境中部署Django时我们一般以Nginx做反向代理和静态文件服务器,这里简单说下Nginx的配置信息。Nginx配置文件通常位于/etc/nginx/conf.d目录下,修改配置文件添加SSL相关信息。

# /etc/nginx/conf.d目录下的配置文件
server {
listen 443 ssl; 监听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证书和私有密钥文件可以上传到服务器上任何一个指定目录,但通常做法是将其上传到Linux的/usr/share/nginx/ssl目录下,所以上述配置信息可以简化为:

# /etc/nginx/conf.d目录下的配置文件
server {
listen 443 ssl; 监听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; # 监听80端口
server_name your_domain.com www.your_domain.com;
return 301 https://$server_name$request_uri; # 永久重定向
}

第三步 修改Django的settings.py

当你的网站支持https后,你可以在settings.py新增如下安全配置,可以给网站和用户数据提供更高级别的保护。这个设置也是django cookiecutter推荐的在生产环境中的默认配置。

# SECURITY安全设置 - 支持http时建议开启
SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
SECURE_SSL_REDIRECT = True # 将所有非SSL请求永久重定向到SSL
SESSION_COOKIE_SECURE = True # 仅通过https传输cookie
CSRF_COOKIE_SECURE = True # 仅通过https传输cookie
SECURE_HSTS_INCLUDE_SUBDOMAINS = True # 严格要求使用https协议传输
SECURE_HSTS_PRELOAD = True # HSTS为
SECURE_HSTS_SECONDS = 60
SECURE_CONTENT_TYPE_NOSNIFF = True # 防止浏览器猜测资产的内容类型

注意:Django的SECURE_SSL_REDIRECT = True也可实现80端口的http请求永久地重定向至https, 与Nginx的301重定向设置选其一即可。Django以上的几个安全设置均依赖下面这个SecurityMiddleware中间件。

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

小结

Django项目上线时配置https非常简单,仅需3步。你学会了吗?

以上就是Django项目如何获得SSL证书与配置HTTPS的详细内容,更多关于Django 获得SSL证书与配置HTTPS的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
tornado框架blog模块分析与使用
Nov 21 Python
python处理json数据中的中文
Mar 06 Python
深入理解NumPy简明教程---数组2
Dec 17 Python
numpy.linspace 生成等差数组的方法
Jul 02 Python
Django如何防止定时任务并发浅析
May 14 Python
selenium+python自动化测试环境搭建步骤
Jun 03 Python
Python绘制二维曲线的日常应用详解
Dec 04 Python
python re模块匹配贪婪和非贪婪模式详解
Feb 11 Python
Python 将 QQ 好友头像生成祝福语的实现代码
May 03 Python
vscode+PyQt5安装详解步骤
Aug 12 Python
Scrapy项目实战之爬取某社区用户详情
Sep 17 Python
Python文件名匹配与文件复制的实现
Dec 11 Python
Python基础之常用库常用方法整理
Apr 30 #Python
Django 实现jwt认证的示例
Python基础之赋值,浅拷贝,深拷贝的区别
Apr 30 #Python
python绘图subplots函数使用模板的示例代码
教你怎么用Python处理excel实现自动化办公
解决python绘图使用subplots出现标题重叠的问题
python数据库批量插入数据的实现(executemany的使用)
Apr 30 #Python
You might like
从零开始的异世界生活:第二季延期后,B站上架了第二部剧场版
2020/05/06 日漫
php存储过程调用实例代码
2013/02/03 PHP
Codeigniter实现发送带附件的邮件
2015/03/19 PHP
PHP统计数值数组中出现频率最多的10个数字的方法
2015/04/20 PHP
PHP实现笛卡尔积算法的实例讲解
2019/12/22 PHP
js变量以及其作用域详解
2020/07/18 Javascript
js读取json的两种常用方法示例介绍
2014/10/19 Javascript
js 通过cookie实现刷新不变化树形菜单
2014/10/30 Javascript
浅谈nodeName,nodeValue,nodeType,typeof 的区别
2015/01/13 Javascript
jQuery实现鼠标滑过Div层背景变颜色的方法
2015/02/17 Javascript
jquery+html5时钟特效代码分享(可设置闹钟并且语音提醒)
2020/03/30 Javascript
浅析JavaScript中浏览器的兼容问题
2016/04/19 Javascript
Bootstrap表单控件使用方法详解
2017/01/11 Javascript
原生js实现淘宝放大镜效果
2020/10/28 Javascript
详解ES6中的Map与Set集合
2019/03/22 Javascript
JavaScript布尔运算符原理使用解析
2020/05/06 Javascript
Python实现网络端口转发和重定向的方法
2016/09/19 Python
python实现Flappy Bird源码
2018/12/24 Python
python遍历小写英文字母的方法
2019/01/02 Python
pytorch 实现在一个优化器中设置多个网络参数的例子
2020/02/20 Python
Python 开发工具PyCharm安装教程图文详解(新手必看)
2020/02/28 Python
Python3如何判断三角形的类型
2020/04/12 Python
斯洛伐克时尚服装网上商店:Cellbes
2016/10/20 全球购物
俄罗斯运动、健康和美容产品在线商店:Lactomin.ru
2020/07/23 全球购物
澳大利亚家具商店:Freedom
2020/12/17 全球购物
EJB的角色和三个对象
2015/12/31 面试题
法学毕业生自我鉴定
2013/11/08 职场文书
竞聘书怎么写,如何写?
2014/03/31 职场文书
加强作风建设演讲稿
2014/10/24 职场文书
实名检举信范文
2015/03/02 职场文书
装饰技术负责人岗位职责
2015/04/13 职场文书
教师个人工作总结范文2015
2015/10/14 职场文书
Pytorch中TensorBoard及torchsummary的使用详解
2021/05/12 Python
html5调用摄像头截图功能
2022/01/18 Javascript
SpringBoot2零基础到精通之异常处理与web原生组件注入
2022/03/22 Java/Android
SQL Server 中的事务介绍
2022/05/20 SQL Server