浅入浅出Flask框架:从HelloWorld开始Flask

June 1st 2014  | Tags: flask, web

2014-06-01

本文主要内容:使用Flask写一个显示”hello world”的web程序,如何配置、调试Flask。

Hello World


按照以下命令建立Flask项目HelloWorld:

mkdir HelloWorld
mkdir HelloWorld/static
mkdir HelloWorld/templates
touch HelloWorld/index.py

statictemplates目录是默认配置,其中static用来存放静态资源,例如图片、js、css文件等。templates存放模板文件。
我们的网站逻辑基本在index.py文件中,当然,也可以给这个文件起其他的名字。

index.py中加入以下内容:

from flask import Flask

app = Flask(__name__)

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

if __name__ == '__main__':
    app.run()

运行index.py:

$ python index.py 
 * Running on http://127.0.0.1:5000/

打开浏览器访问http://127.0.0.1:5000/,浏览页面上将出现Hello World!
终端里会显示下面的信息:

127.0.0.1 - - [16/May/2014 10:29:08] "GET / HTTP/1.1" 200 -

变量app是一个Flask实例,通过下面的方式:

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

当客户端访问/时,将响应hello_world()函数返回的内容。注意,这不是返回Hello World!这么简单,Hello World!只是HTTP响应报文的实体部分,状态码等信息既可以由Flask自动处理,也可以通过编程来制定。

修改Flask的目录配置


Flask使用static目录存放静态资源,这是可以更改的,请在index.py的:

app = Flask(__name__)

中为Flask多加几个参数值,这些参数请参考__doc__

from flask import Flask
print Flask.__doc__

调试


上面的index.py中以app.run()方式运行,这种方式下,如果服务器端出现错误是不会在客户端显示的。但是在开发环境中,显示错误信息是很有必要的,要显示错误信息,应该以下面的方式运行Flask:

app.run(debug=True)

绑定网络接口和端口


默认情况下,Flask绑定IP为127.0.0.1,端口为5000,可以通过下面的方式指定:

app.run(host='0.0.0.0', port=80, debug=True)

由于绑定了80端口,需要使用root权限运行index.py。

(完)