`

在 Django/Flask 开发服务器上使用 HTTPS

阅读更多

使用 Django 或 Flask 这种框架开发 web app 的时候一般都会用内建服务器开发和调试程序,等程序完成后再移交到生产环境部署。问题是这些内建服务器通常都不支持 HTTPS,我们想在开发的时候就能够使用和测试 HTTPS,不想还没测试就部署到生产环境,所以我们需要内建服务器能支持 HTTPS.

这个问题可以通过一个外部程序 stunnel 来解决,stunnel 的作用是通过 OpenSSL 库对 TCP 会话进行加密,建立起一个安全通道,保护没有加密功能或未加密的程序。其主要功能有两个:

  • 接收未加密的数据流,进行 SSL 加密,然后把加密后的数据流通过网络发送出去;
  • 对已加密的数据流进行解密,并将解密后的数据流其通过网络发送给另一个程序。

了解了 stunnel 的功能后我们很容易就能想到利用 stunnel 建立一个 SSL 加密通道绑定到 Django/Flask 内建服务器上,stunnel 启动 443 端口接受用户的 HTTPS 请求,解密后发送给内建服务器的 8000 端口处理,内建服务器处理完后发送数据给 stunnel 然后加密后返回给浏览器用户。

好吧,上面说了一堆貌似很复杂,其实使用 stunnel 很简单。

在 Django/Flask 开发服务器所在的机器上安装 stunnel:

# yum install stunnel(在 CentOS 上)

或者

$ sudo apt-get install stunnel4(在 Ubuntu 上)

如果没有购买 SSL 证书的话自己生成一个,对了,这个文件的权限必须是 600 哦:

# openssl req -new -x509 -days 365 -nodes -out vpsee.pem -keyout vpsee.pem

# chmod 600 vpsee.pem

新建一个配置文件叫做 https,然后用 stunnel 执行这个配置文件,启动 443 端口连接到 Django/Flask 内建服务器的 8000 端口:

# vi https
pid =
cert = vpsee.pem
debug = 7
foreground = yes

[https]
accept = 443
connect = 8000

# stunnel https

启动 Django 内建服务器绑定到上面配置文件提到的 8000 端口:

# HTTPS=1 python manage.py runserver 0.0.0.0:8000

启动 Flask 内建服务器不需要特别的,改变端口到 8000,按照正常的方式启动就可以了:

# vi run.py
#!flask/bin/python
from app import app
app.run(host='0.0.0.0', port=8000, debug = True)

# ./run.py
 * Running on http://0.0.0.0:8000/
 * Restarting with reloader

 

分享到:
评论

相关推荐

    Linux服务器部署文章配套资源用于python+Django/flask+uWSGI+Nginx

    3. **配置项目**:在服务器上创建并初始化Django项目或者Flask应用,编写好业务逻辑。 4. **配置uWSGI**:安装uWSGI,编写uWSGI配置文件,指定Python解释器路径、项目位置、进程数等参数。 5. **配置Nginx**:安装...

    Python高效开发实战 Django Tornado Flask Twisted 中文版 完整版 带书签

    《Python高效开发实战》这本书全面覆盖了Python web开发的四大框架——Django、Tornado、Flask和Twisted,旨在帮助读者深入理解并熟练运用这些框架进行高效的Web应用开发。以下将详细介绍这四个框架及其核心知识点。...

    Python高效开发实战 Django Tornado Flask Twisted

    在探讨Python高效开发实战中,涉及到的主要框架有Django、Tornado、Flask以及Twisted。这些框架是Python语言中非常流行的后端开发工具,各有特色,在不同的应用场景中表现优异。 Django是一个高级的Python Web框架...

    django+flask连接天猫精灵使用语音demo

    在本文中,我们将深入探讨如何使用Django和Flask框架来连接天猫精灵并实现一个语音识别的DEMO。首先,我们需要理解这两个Web框架的基本概念。 Django是一个高级的Python Web框架,它鼓励快速开发和干净、实用的设计...

    Django&flask;

    9. **内置开发服务器**:Django 提供了一个内置的开发服务器,方便开发者快速测试和调试应用。 **Flask 框架** Flask 是另一个 Python Web 开发框架,它以轻量级和模块化著称。Flask 的主要特点包括: 1. **微...

    python微服务案例-DJango-Flask-Vue

    在本项目中,“python微服务案例-DJango-Flask-Vue”,我们看到了一个综合性的应用,它利用Python的两种主流Web框架——Django和Flask,以及前端的Vue.js来构建微服务架构。微服务架构是一种将单一应用程序分解为一...

    Flask+Web开发实战,flaskweb开发实战pdf,Python

    虽然Flask本身不包含内置的服务器,但在开发阶段可以使用`run()`方法快速启动一个简单的服务器。在生产环境中,通常会使用Gunicorn或uWSGI这样的WSGI服务器配合Nginx进行部署,以获得更好的性能和稳定性。 **总结**...

    整理django和flask谁更简单.docx

    **Django**是一个全功能的Web框架,强调“ batteries included ”的理念,提供了丰富的内置功能,如ORM(对象关系映射)、数据库管理、身份验证和授权、表单处理、内置开发服务器等。Django遵循MVT(模型-视图-模板...

    Python高效开发实战:Django、Tornado、Flask、Twisted 随书源代码

    Python是当今世界上最受欢迎的编程语言之一,特别是在Web开发领域,它拥有强大的框架支持。本篇文章将深入探讨四个知名的Python Web框架:Django、Tornado、Flask和Twisted,并基于提供的随书源代码进行分析。 首先...

    Python高效开发实战——Django、Tornado、Flask、Twisted 的随书完整源代码

    本资源提供了四个知名Web框架——Django、Tornado、Flask和Twisted的随书完整源代码,帮助开发者深入理解和实践这些框架,提升开发效率。以下是对这四个框架的详细介绍: 1. Django:Django是一个高级的Python Web...

    Python高效开发实战:Django、Tornado、Flask、Twisted

    在Python的Web开发领域,Django、Tornado、Flask和Twisted是四个非常重要的框架,它们各自有着独特的特性和适用场景。 Django,被誉为“ batteries included ”的Web框架,提供了一站式的解决方案,包括ORM(对象...

    Flask开发笔记总结

    在本文中,我们将深入探讨Flask开发的相关知识点,包括Web框架的基本原理、Flask的特点、与Django的对比,以及Flask的扩展包和基本应用。 首先,让我们了解Web开发的基础,即HTTP通信与Web框架。HTTP是互联网上应用...

    整理django和flask谁更简单 (2).pdf

    Django以其“ batteries included ”的理念而闻名,提供了许多内置功能,如ORM(对象关系映射)、身份验证和授权、数据库迁移工具、强大的URL路由系统、模板引擎以及内置的开发服务器。Django特别适合大型、复杂的...

    Flask&Django.zip

    4. **WSGI服务器**:Flask不包含内置的服务器,但可以与Gunicorn或uWSGI等WSGI服务器配合使用进行部署。 5. **扩展性**:通过各种扩展(例如Flask-SQLAlchemy、Flask-WTF等)增强Flask的功能。 **Django** 是一个更...

    Flask_Web全栈开发阶段-flask框架.zip

    在本压缩包“Flask_Web全栈开发阶段-flask框架.zip”中,核心主题是关于使用Flask框架进行Web全栈开发的知识。Flask是一个轻量级的Python Web服务器网关接口(WSGI)应用框架,由Armin Ronacher开发。它提供了基础的...

    知识领域: 后端开发 技术关键词: Node.js、Django、Flask 内容关键词: RESTful API、数据库管理、

    技术关键词: Node.js、Django、Flask 内容关键词: RESTful API、数据库管理、身份验证 用途: 开发可靠、高效的服务器端应用程序,支持前端交互 资源描述: "Node.js官方文档"是学习和使用Node.js的首要参考资源,包含...

    基于django&flask的技术交流社区--前后端分离开发.zip

    在本项目中,"基于django&flask的技术交流社区--前后端分离开发"是一个结合了两种流行的Python web框架——Django和Flask的项目。它旨在构建一个技术讨论和分享平台,采用前后端分离的开发模式,提高了项目的可扩展...

    对Python各种框架Django、Flask、Scrapy、Selenium、Ansible、Locust等的深入.zip

    在本资料中,我们将深入探讨六个重要的Python框架:Django、Flask、Scrapy、Selenium、Ansible以及Locust。 1. Django:Django被誉为“快乐的Web开发框架”,它是一个高级的、基于模型-视图-控制器(MVC)架构的...

Global site tag (gtag.js) - Google Analytics