Hello World

Hello World 开始

本节主要内容:使用Flask写一个显示 "Hello World!"的web程序,如何配置、调试Flask。

创建项目

我们手动创建文件夹和文件结构如下:

py/

  ├ static/ # static用来存放静态资源,例如图片、js、css文件等

  ├ templates/ # templates存放模板文件

  ├ server.py

我们的网站逻辑基本在server.py文件中,当然,也可以给这个文件起个其他的名字。

在server.py中加入以下内容:

from flask import Flask

app = Flask(__name__)

@app.route('/')

def hello_world():

    return 'Hello World!'

if __name__ == '__main__':

    app.run()

运行server.py:

python3 server.py

* Running on http://127.0.0.1:5000/


打开浏览器访问http://127.0.0.1:5000/



代码解析

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

@app.route('/')

def hello_world():

    return 'Hello World!'

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


修改Flask的配置

app = Flask(__name__)

上面的代码中,python内置变量__name__的值是字符串__main__ 。Flask类将这个参数作为程序名称。当然这个是可以自定义的,比如:

app = Flask("myapp")

Flask默认使用static目录存放静态资源,templates目录存放模板,也可以通过设置参数更改:

app = Flask("myapp", static_folder="path1", template_folder="path2")

以上我们指定静态资源目录为path1, 模板目录为 path2。

更多参数请参考__doc__:

from flask import Flask

print(Flask.__doc__)


调试模式

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

app.run(debug=True)

将debug设置为True的另一个好处是,程序启动后,会自动检测源码是否发生变化,若有变化则自动重启程序。这可以帮我们省下很多时间。

还可以使用这种途径开启调试模式:

app.debug = True

app.run()


绑定IP和端口

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

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

0.0.0.0代表电脑所有的IP。以上我们绑定了8080端口, 启动服务后我们访问的网址将是: http://127.0.0.1:8080/

你可能感兴趣的:(Hello World)