位置: 编程技术 - 正文

深度定制Python的Flask框架开发环境的一些技巧总结

编辑:rootadmin

推荐整理分享深度定制Python的Flask框架开发环境的一些技巧总结,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Flask 环境配置你的应用程序可能需要大量的软件包才能正常的工作。如果都不需要 Flask 包的话,你有可能读错了教程。当应用程序运行的时候,你的应用程序的 环境 基本上是所有一切事情的根基。我们是幸运的,因为有许多方式使得我们能够轻松地管理我们的环境。使用 virtualenv 管理你的环境virtualenv 是用于在所谓 虚拟环境 中隔离你的应用程序的一个工具。一个虚拟环境是包含了你的应用依赖的软件的一个目录。一个虚拟环境也能够改变你的环境变量以维持你的开发环境包含的环境变量。不用下载包,像 Flask, 到你系统级或者用户级的包目录,我们可以下载它们到一个独立的并且只为我们应用使用的目录。这就可以很容易地指定使用的 Python 的版本以及每一个项目依赖的包。Virtualenv 也可以让你在不同的项目中使用相同的包的不同版本。这种灵活性可能是十分重要的,如果你正使用一个旧的系统并且它的上面有几个项目需要不同的版本。当使用 virtualenv 的时候,你通常只需要安装几个的 Python 包在你的系统上。其中一个就是 virtualenv 本身。你可以使用 Pip 来安装 virtualenv 包。一旦在你的系统上安装了 virtualenv,你可以开始创建虚拟环境。前往你项目所在的目录并且运行 virtualenv 命令。它需要一个参数,这个参数就是虚拟环境的目标目录。下面展示了它大概的样子。

virtualenv 创建一个新的目录,依赖包将会安装到这个目录中。一旦新的虚拟环境已经创建,你必须激活它,通过发动创建在虚拟环境里的 bin/activate 脚本。

bin/activate 脚本对你的 shell 环境变量进行一些改变以致一切都指向新的虚拟环境而不是全局系统。你可以在上面的代码块中看到效果。激活后,python 命令指向虚拟环境的中 Python 的 bin 目录。当虚拟环境激活后,使用 Pip 安装的依赖包会被下载到虚拟环境中而不是全局系统。你可能会注意到 shell 中的提示符也已经改变了。virtualenv 预先设定目前激活虚拟环境的名称,因此你会知道你不是在全局系统上工作。你可以通过运行 deactivate 命令停用你的虚拟环境。

virtualenvwrappervirtualenvwrapper 是一个用于管理 virtualenv 创建的虚拟环境的软件包。我不想提到这个工具,直到你看到了 virtualenv 的基础知识以便你理解它改善了什么以及为什么我们应该使用它。上一部分创建的虚拟环境目录会给你的项目库带来一些混乱。你只需要激活虚拟环境和它进行交互,但是它不应该出现在版本控制中,因此这个虚拟环境目录就不应该在这里。解决方案就是使用 virtualenvwrapper。这个软件包会把所有你的虚拟环境放在一个目录的方式,通常默认是在 ~/.virtualenvs/。要安装 virtualenvwrapper,请按照文档中的说明,文档位于 。请确保在安装 virtualenvwrapper 之前你已经停用所有的虚拟环境。你需要把它安装在全局系统中,而不是虚拟环境中。现在,不用运行 virtualenv 来创建一个环境,你需要运行 mkvirtualenv:

mkvirtualenv 在你虚拟环境目录中创建一个文件夹并且为你激活虚拟环境。就像上面的 virtualenv 一样,python 以及 pip 指向虚拟环境中而不是全局系统的二进制文件。要激活一个特定的环境,使用命令:workon [environment name]。deactivate 仍然会停用虚拟环境。安装依赖包随着项目的发展,你会发现依赖包的列表会增大。需要几十个 Python 包来运行一个 Flask 应用程序的情况并不少见。管理这些最简单的方法是用一个简单的文本文件。Pip 能够生成一个列出所有已安装的包的文本文件。在一个新的系统上,或者在一个新的刚创建的环境上也能读取文件中的列表并且安装它们中每一个。pip freeze:requirements.txt 是一个文本文件,它被许多 Flask 应用程序用来列出运行应用所有需要的包。这个代码块用来说明如何创建这个文件接着下一个代码块用来说明在一个新环境中如果使用这个文件来安装依赖包。人工管理依赖包随着项目的发展,你可能会发现 pip freeze 列出的某些包实际上并不是运行应用必须的。你安装这些包仅仅为开发用的。pip freeze 并不能区分,它仅仅列出目前已经安装的包。因此,你可能要手动地管理这些依赖包。你可以分别把那些运行应用必须的包放入 require_run.txt 以及那些开发应用程序需要的包放入 require_dev.txt 。版本控制选择一个版本控制系统并且使用它。我推荐 Git。从我所看到的,Git 是这些天来新项目最流行的选择。能够删除代码而不必担心犯了一个不可逆转的错误是非常宝贵的。你也可以让你的项目摆脱大量注释掉的代码的困扰,因为你可以删除它们,以后如有需要可以恢复它们。另外,你可以在 GitHub,Bitbucket 或者你自己的 Gitolite 服务器上备份整个项目。置身版本控制之外的文件我通常会让一个文件置身版本控制之外有两个原因:要么就是它会让整个项目显得混乱,要么它就是一个很隐私的密钥/证书。编译的 .pyc 文件和虚拟环境 — 如果由于某些原因你没有使用 virtualenvwrapper — 就是让项目显得很混乱的例子。它们不需要在版本控制之中因为它们能够分别地从 .py 文件和你的 requirements.txt 文件重新创建。API 秘钥,应用程序秘钥以及数据库证书是很隐私的密钥/证书的示例。它们不应该出现在版本控制中因为它们的曝光将是一个巨大的安全漏洞。当做跟安全有关的决定的时候,我总是喜欢假设我的版本库将在某个时候变成公开的。这就意味着要保守秘密并且从不假设一个安全漏洞不会被发现,“谁来猜猜他们能做到”这类型的假设被称为通过隐匿来实现安全,这是十分槽糕的策略。当使用 Git 的时候,你可以在你的版本库中创建名为 .gitignore 的一个特殊文件。在这个文件里,使用列表通配符来匹配文件名。任何匹配其中一个模式的文件名都会被 Git 给忽略掉。我推荐使用 .gitignore 来控制不需要版本控制的文件。例如:Instance 文件夹是用于以一种更安全地方式提供给你的应用程序敏感配置变量。我将会在后面更多地谈到它。你可以阅读更多的关于 .gitignore 的内容从这里: 有一个称为调试模式方便的功能。要打开调试功能的话,你只必须在你的开发配置中设置 debug = True。当它打开的时候,服务器会在代码变化的时候自动加载并且出错的时候会伴随着一个堆栈跟踪和一个交互式控制台。小心!不要在生产环境中使用调试模式。交互式控制台允许执行任意代码并会是一个巨大的安全漏洞。2.Flask-DebugToolbarFlask-DebugToolbar 是另一个非常了不起的工具,它可以帮助在你的应用程序中调试问题。在调试模式下,它会把一个侧边栏置于你的应用程序的每一页上。侧边栏提供了有关 SQL 查询,日志记录,版本,模板,配置和其它有趣的信息,使得更容易地跟踪问题。看看快速入门中的 调试模式。在 Flask 官方文档 中有一些关于错误处理,日志记录以及使用调试器等不错的信息。

Flask 工程配置当你学习 Flask 的时候,配置看起来很简单。你只要在 config.py 中定义一些变量接着一切就能工作了。当你开始必须要管理生产应用的配置的时候,这些简单性开始消失了。你可能需要保护 API 密钥以及为不同的环境使用不同的配置(例如,开发和生产环境)。在本章节中我们会介绍 Flask 一些先进的功能,它可以使得管理配置容易些。简单的例子一个简单的应用程序可能不会需要任何这些复杂的功能。你可能只需要把 config.py 放在你的仓库/版本库的根目录并且在 app.py 或者 yourapp/\_init\_.py 中加载它。config.py 文件中应该每行包含一个配置变量赋值。当你的应用程序初始化的时候,在 config.py 中的配置变量用于配置 Flask 和它的扩展并且它们能够通过 app.config 字典访问到 ? 例如,app.config["DEBUG"]。

配置的变量可以被 Flask,它的扩展或者你来使用。这个例子中, 每当我们在一封事务性邮件中需要默认的 “发件人” 的时候,我们可以使用 app.config["MAIL_FROM_EMAIL"] ? 例如,密码重置。把这些信息放置于一个配置变量中使得以后能够容易地修改它。

DEBUG: 为你提供了调试错误的一些方便的工具。 这包括一个基于 Web 的堆栈跟踪和交互式的 Python 控制台。在开发环境中设置成 True; 生产环境中设置成 False。 SECRET_KEY:这是 Flask 用来为 cookies 签名的密钥。 它也能被像 Flask-Bcrypt 类的扩展使用。 你应该在你的实例文件夹中定义它, 这样可以远离版本控制。 你可以在下一个章节中阅读更多关于示例文件夹的内容。一般情况下这应该是一个复杂的随机值。 BCRYPT_LEVEL:如果你使用 Flask-Bcrypt 来散列用户密码的话, 你需要指定一个“循环”数,这个数是在执行散列密码的 算法需要的。如果你不使用 Flask-Bcrypt,你可以 忽略这里。用于散列密码的循环数越大,攻击者猜测密码 的时间会越长。同时,循环数越大会增加散列密码的时间。后面我们会给出在 Flask 应用中 使用 Bcrypt 的一些最佳实践。

确保在生产环境中 DEBUG 设置成 False。如果保留 DEBUG 为 True,它允许用户在你的服务器上执行任意的 Python。实例文件夹有时候你需要定义包含敏感信息的配置变量。我们想要从 config.py 中分离这些变量并且让它们保留在仓库/版本库之外。你可能会隐藏像数据库密码以及 API 密钥的一些敏感信息,或者定义于特定于指定机器的配置变量。为让实现这些要求更加容易些,Flask 提供了一个叫做 instance folders 的功能。实例文件夹是仓库/版本库下的一个子目录并且包含专门为这个应用程序的实例的一个配置文件。我们不希望它提交到版本控制。

深度定制Python的Flask框架开发环境的一些技巧总结

使用实例文件夹我们使用 app.config.from_pyfile() 来从一个实例文件夹中加载配置变量。当我们调用 Flask() 来创建我们的应用的时候,如果我们设置了 instance_relative_config=True, app.config.from_pyfile() 将会从 instance/ 目录加载指定文件。

现在我们可以像在 config.py 中那样在 instance/config.py 中定义配置变量。你也应该把你的实例文件夹加入到版本控制系统的忽略列表中。要使用 Git 做到这一点的话,你需要在 .gitignore 新的一行中添加 instance/ 。密钥实例文件夹的隐私性成为在其里面定义不想暴露到版本控制的密钥的最佳候选。这些密钥可能包含了你的应用的密钥或者第三方 API 密钥。如果你的应用是开源的或者以后可能会公开的话,这一点特别重要。我们通常要求其他用户或者贡献者使用自己的密钥。

基于环境的配置如果在你的生产环境和开发环境中的差异非常小的话,你可能想要使用实例文件夹来处理配置的变化。定义在 'instance/config.py' 文件中的配置变量能够覆盖 'config.py' 中的值。你只需要在 'app.config.from_object()' 后调用 'app.config.from_pyfile()'。这样用法的好处之一就是在不同的机器上修改你的应用的配置。

在生产环境上,我们略去上面 'instance/-config.py' 中的配置变量,它会退回到定义在 'config.py' 中的值。了解更多关于 Flask-SQLAlchemy 的 配置项。(中文版的位于: 给我们选择配置文件的能力,它可以基于一个环境变量的值来加载不同的配置文件。这就意味着在我们的仓库/版本库里,我们可以有多个配置文件并且总会加载正确的那一个。一旦我们有多个配置文件的话,我可以把它们移入它们自己 config 文件夹中。

在上面的文件列表中我们有多个不同的配置文件。

config/default.py: 默认的配置值,可用于所有的环境或者被个人的环境给覆盖。 config/development.py: 用于开发环境的配置值。这里你可能会指定本地数据库的 URI。 config/production.py: 用于生产环境的配置值。在这里 DEBUG 一定要设置成 False。 config/staging.py: 根据开发进度,你可能会有一个模拟生产环境,这个文件主要用于这种场景。

为了决定要加载哪个配置文件,我们会调用 'app.config.from_envvar()'。

环境变量的值应该是配置文件的绝对路径。我们如何设置这个环境变量取决于我们运行应用所在的平台。如果我们运行在一个普通的 Linux 服务器上,我们可以编写一个设置环境变量的 shell 脚本并且运行 run.py。

start.sh 对于每一个环境都是独一无二的,因此它应该被排除在版本控制之外。在 Heroku 上,我们需要使用 Heroku 工具来设置环境变量。这种设置方式也适用于其它的 PaaS 平台。

Python的Flask框架标配模板引擎Jinja2的使用教程 Jinja2需要Python2.4以上的版本。安装按照Jinja有多种方式,你可以根据需要选择不同的按照方式。使用easy_install或pip:#sudoeasy_installJinja2#sudopipinstallJinja2这两

使用Python的Flask框架表单插件Flask-WTF实现Web登录验证 表单是让用户与我们的网页应用程序交互的基本元素。Flask本身并不会帮助我们处理表单,但是Flask-WTF扩展让我们在我们的Flask应用程序中使用流行的WTFo

Python使用SocketServer模块编写基本服务器程序的教程 SocketServer简化了网络服务器的编写。它有4个类:TCPServer,UDPServer,UnixStreamServer,UnixDatagramServer。这4个类是同步进行处理的,另外通过ForkingMixIn和Threadin

标签: 深度定制Python的Flask框架开发环境的一些技巧总结

本文链接地址:https://www.jiuchutong.com/biancheng/386199.html 转载请保留说明!

上一篇:使用python绘制常用的图表(测验2:python基本图形绘制)

下一篇:Python的Flask框架标配模板引擎Jinja2的使用教程(flask框架下使用scrapy框架)

  • 社保由税务局征收
  • 临时工工资列支工资吗
  • 公司有残疾人需要交税吗
  • 会计制度方法
  • 预缴纳税和年度汇缴
  • 除湿机 哪个好
  • 公司分立是不是法人
  • 现金日记账根据哪些凭证登记
  • 申报怎么打印
  • 白酒在哪个环节征收消费税
  • 营改增之后账务怎么处理
  • 创投资本投入资金如何做账?
  • 资金账簿印花税减半征收是从什么时候开始的
  • 货款为现金如何做记账账款凭证?
  • 小规模纳税人未申报怎么处理
  • 公司在原有生产领域内充分利用
  • 出口退税账务处理例题
  • 外贸过程中产生的问题
  • 公司为员工购买五险一金是什么意思
  • 增加以前年度收入是否需要更正申报年报
  • 交税四舍五入差额怎么处理
  • 递延所得税收益计算公式
  • 证券投资基金管理人的职权
  • 股票现金分红
  • 税前扣除的固定资产
  • 企业开增值税普通发票 电子版
  • 财务报表申报完可以修改吗
  • 企业一次性支付多年费用 不摊销
  • mac怎么开机
  • php生成验证码的方法
  • php获取ftp文件目录
  • 福利企业即征即退优惠政策
  • php chr
  • 装饰工程公司主要做什么
  • php 动态调用类方法
  • thinkphp框架入门
  • 小程序从入门到精通
  • 大二期末要考试吗
  • 企业会计准则规定了
  • 出差补贴是额外的吗
  • centos7.3安装
  • mysql5.7性能优化
  • 百旺金赋怎么开红字发票
  • 应收利息和应收股利属于什么科目
  • 本月冲红上月发票后的税款能抵减吗
  • 补缴以前年度所得税及滞纳金账务处理
  • 退客户多余货款怎么处理
  • 并购贷款是固定资产贷款吗
  • 农业免税企业开票有限额吗
  • 收到国税退税收怎么做账
  • 对公账户可以报税吗
  • 滴滴普通发票
  • 日常费用报销表格
  • 错开发票所需要提供的资料以及时效要求是?
  • 企业的研发活动阶段包括
  • mysql忘记了初始密码
  • mysql5.7.20安装
  • mysql数据库windows
  • mysql数据库基础与实践课后答案
  • win10下面任务栏
  • 计算机彻底删除文件的方法
  • centos6.2安装教程
  • 录制界面
  • 如何解决windows无法访问指定设备
  • 在linux操作系统中
  • linux的kill函数
  • win7系统文件夹怎么加密
  • 比较好的jquery教程
  • css示范例子
  • python占位
  • bootstrap需要学多久
  • javascript中window.onload
  • javascript 进阶篇3 Ajax 、JSON、 Prototype介绍
  • jQuery插件是什么
  • jquery foreach循环
  • ca证书密码是什么
  • 电子税务局校验码
  • 2023年内蒙古房贷利率
  • 为什么购进固定资产不得抵扣
  • 安徽国家税务局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设