用flask开发,从hello world!开始
项目名web_develop,在下面新建hello.py文件
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'Hello World'
if __name__ == '__main__':
app.run(host='0.0.0.0',port=9000)
然后在命令行执行
python3 hello.py
然后在浏览器打开http://0.0.0.0:9000/技能看到输出:
Hello World
脚本语言的第一行,目的就是指出,你想要你的这个文件中的代码用什么可执行程序去运行它,就这么简单
@#!/usr/bin/python是告诉操作系统执行这个脚本的时候,调用/usr/bin下的python解释器;
@#!/usr/bin/env python这种用法是为了防止操作系统用户没有将python装在默认的/usr/bin路径里。当系统看到这一行的时候,首先会到env设置里查找python的安装路径,再调用对应路径下的解释器程序完成操作。
@#!/usr/bin/python相当于写死了python路径;
@#!/usr/bin/env python会去环境设置寻找python目录,推荐这种写法
第二行 注释是为了告诉Python解释器,按照UTF-8编码读取源代码,否则,你在源代码中写的中文输出可能会有乱码。
第三行,引入Flask类,Flask类实现了一个WSGI应用。
第五行 app是Flask的实例,它接收包或者模块的名字作为参数,但一般都是传递name。让flask.helpers.get_root_path函数通过传入这个名字确定程序的根目录,以便获得静态资源文件和模板文件的目录
第7-9行,使用app.route装饰器会将URL和执行的视图函数的关系保存到app.url_map属性上。处理URL和视图函数的关系的程序就是路由,这里的视图函数就是hello_world。
第12行,使用这个判断可以保证当其他文件引用这个文件的时候(例如 "from hello import app")不会执行这个判断内的代码,也就是不会执行app.run函数
第13行,执行app.run就可以启动服务了。默认Flask只监听虚拟机的本地127.0.0.1这个地址,端口为5000。而我们对虚拟机做的端口转发端口是9000,所以需要指定host和port参数,0.0.0.0表示监听所有地址,这样就可以在本机访问了。服务器启动后,会调用werkzeug.serving.BaseWSGIServer处理请求,实际上还是使用标准库BaseHeepServer.HTTPServer,通过select.select做0.5秒的“while True”的时间轮询。当我们访问“http://127.0.0.1:9000/”,通过app.url_map找到注册的“/”这个URL模式,就找到了对应的hello_word函数执行,返回“Hello World”,状态码为200,如果访问一个不存在的路径,如访问“http://127.0.0.1:9000/a”找不到对应的模式,就会向浏览器返回“ Not Fount ”,状态码为404。
还要注意的是,默认的app.run的启动方式只适合调试,不要在实际生产环境中使用,生产环境应该使用Gunicorn或者uWSGI。
其他的werkzeug自带类型还包括ThreadedWSGIServer和ForkingWSGIServer。