Flask依赖的核心模块werkzeug

如果你不相信努力和时光,那么成果就会是第一个选择辜负你的。不要去否定你自己的过去,也不要用你的过去牵扯你现在的努力和对未来的展望。不是因为拥有希望你才去努力,而是去努力了,你才有可能看到希望的光芒。Flask依赖的核心模块werkzeug,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

Flask依赖的核心模块werkzeug

Flask的web框架实现

Flask是python Web框架,自然要遵 WSGI 规范,需要同时实现服务端程序+应用程序,并且要丰富完善请求和响应的处理。
Flask自身并没有实现WSGI,而是依赖werkzeug来实现WSGI程序。在开发时,我们使用flask run命令启动Flask,其中服务端程序就是由Werkzeug提供的,应用程序就是Flask中程序实例app
flask demo

import time
from flask import Flask

app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello World!'

在生产环境中,通常需要一个更强健,性能更高的WSGI服务器。这些 WSGI 服务器也被称为 WSGI 容器(Standalone WSGI Container),因为它们可以高效的处理HTTP请求,调用我们编写的应用程序。这通常有很多选择,比如

不论是内置的用于开发时使用的服务器Werkzeug,还是gunicornuWSGIGeventWaitres等 实现了规范的WSGI服务器,都可以用运行我们的Flask。
Flask依赖的核心模块werkzeug

werkzeug

由于Flask是依赖werkzeug来实现的服务端程序,下面来认识同样由Falsk团队开发的werkzeug模块。
Werkzeug是一个德语名字,译为“工具”的意思,在python中是一个专门用来处理HTTP和WSGI的工具库,可以方便的在python程序中处理HTTP协议相关内容。需要注意的是werkzeug不是一个web服务器,也不是一个web框架,而是一个工具包。官方的介绍说是一个WSGI工具包,它可以作为一个Web框架的服务端库, 因为它封装好了很多Web框架的东西,例如 Request,Response等等。安装flask时会依赖的安装好werkzeug。

简单demo
werkzeug_demo.py

from werkzeug.serving import run_simple

def application(environ, start_response):
    start_response('200 ok', [('Content-Type', 'text/html')])
    return [b'<h1>hello world!</h1>']

if __name__ == "__main__":
    run_simple('localhost', 5000, application)

Flask依赖的核心模块werkzeug
Flask依赖的核心模块werkzeug

flask使用werkzeug

flask中如何使用werkzeug作为服务端程序呢?
在启动flask时使用的flask run命令,本质上就是通过werkzeug来启动一个服务端程序。

def run(self, host='localhost', port=5000, **options):
    from werkzeug import run_simple
    if 'debug' in options:
        self.debug = options.pop('debug')
    options.setdefault('use_reloader', self.debug)
    options.setdefault('use_debugger', self.debug)
    return run_simple(host, port, self, **options)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/196545.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!