Flask 前戏


官网:欢迎来到 Flask 的世界 — Flask 中文文档 (2.0.2) (dormousehole.readthedocs.io)

使用前记得需要安装:flask

入门简单小例子

代码:

from flask import Flask

app = Flask(__name__)


# 路由用来匹配url,在这个url下的函数
@app.route('/')
def hello_world():
    return "

Hello, World!

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


运行结果:点击运行下面的连接就能看到右边入图的网页结果



  1. 首先我们导入了 Flask 类。该类的实例将会成为我们的 WSGI 应用。

  2. 接着我们创建一个该类的实例。第一个参数是应用模块或者包的名称。 __name__ 是一个适用于大多数情况的快捷方式。有了这个参数, Flask 才能知道在哪里可以找到模板和静态文件等东西。

  3. 然后我们使用 route() 装饰器来告诉 Flask 触发函数 的 URL 。

  4. 函数返回需要在用户浏览器中显示的信息。默认的内容类型是 HTML ,因此字 符串中的 HTML 会被浏览器渲染。

把它保存为 hello.py 或其他类似名称。请不要使用 flask.py 作为应用名称,这会与 Flask 本身发生冲突。

可以使用 flask 命令或者 python 的 -m 开关来运行这个应 用。在运行应用之前,需要在终端里导出 FLASK_APP 环境变量:

 

2、将URL中的参数传进HTML中显示

当返回 HTML ( Flask 中的默认响应类型)时,为了防止注入攻击,所有用户提 供的值在输出渲染前必须被转义。使用 Jinja (这个稍后会介绍)渲染的 HTML 模板会自动执行此操作。

在下面展示的 escape() 可以手动转义。因为保持简洁的原 因,在多数示例中它被省略了,但您应该始终留心处理不可信的数据。

from flask import Flask
from markupsafe import escape
app = Flask(__name__)


@app.route("/")
def hello(name):
    return f"Hello, {escape(name)}!"

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

可以看到它会把http://127.0.0.1:5000/ 把参数写到html中

 记得:只要关闭了app.py 的运行网页就没无法访问

路由

现代 web 应用都使用有意义的 URL ,这样有助于用户记忆,网页会更得到用户的青睐, 提高回头率。

使用 route()装饰器来把函数绑定到 URL:

from flask import Flask

app = Flask(__name__)

# 路由用来匹配url,在这个url下的函数
@app.route('/')
def hello_world():
    return "

Hello, World!

" # http://127.0.0.1:5000/first 这个网址对应的函数 @app.route("/first") def first_func(): return "This is, first Function!" # http://127.0.0.1:5000/two 这个网址对应的函数 @app.route("/2") def two_func(): return "This is, two Function!" if __name__ == '__main__': app.run()

看一下对应的三个URL的情况







这一下你应该能明白路由器的作用了吧

变量规则

通过把 URL 的一部分标记为  就可以在 URL 中添加变量。标记的 部分会作为关键字参数传递给函数。通过使用  ,可以 选择性的加上一个转换器,为变量指定规则。

from flask import Flask
from markupsafe import escape
app = Flask(__name__)


# 路由用来匹配url,在这个url下的函数
@app.route('/')
def hello_world():
    return "

Hello, World!

" from markupsafe import escape @app.route('/test/') def show_user_profile(username): if 1 == username: return f'{escape(username)},是一个整数' if '1' == username: return f'{escape(username)},是字符串'



可以看到url的值默认是字串,可以指定为其它类型
把路由器改成
@app.route('/test/')




 同理:

string:缺省值) 接受任何不包含斜杠的文本

int:接受正整数

float:接受正浮点数

path:类似 string ,但可以包含斜杠

uuid:接受 UUID 字符串

唯一的 URL / 重定向行为

以下两条规则的不同之处在于是否使用尾部的斜杠。:

@app.route('/test1/')

test1的 URL 是中规中矩的,尾部有一个斜杠,看起来就如同一个文件 夹。访问一个没有斜杠结尾的 URL ( /test1)时 Flask 会自动进行重 定向,帮您在尾部加上一个斜杠( /test1 )。

@app.route('/test2')

test2的 URL 没有尾部斜杠,因此其行为表现与一个文件类似。如果访问这 个 URL 时添加了尾部斜杠(`` /test2/ `` )就会得到一个 404 “未找到” 错 误。这样可以保持 URL 唯一,并有助于搜索引擎重复索引同一页面。

URL 构建

url_for()函数用于构建指定函数的 URL。它把函数名称作为第一个 参数。它可以接受任意个关键字参数,每个关键字参数对应 URL 中的变量。未知变量 将添加到 URL 中作为查询参数。

为什么不在把 URL 写死在模板中,而要使用反转函数url_for()动态构建?

  1. 反转通常比硬编码 URL 的描述性更好。

  2. 您可以只在一个地方改变 URL ,而不用到处乱找。

  3. URL 创建会为您处理特殊字符的转义,比较直观。

  4. 生产的路径总是绝对路径,可以避免相对路径产生副作用。

  5. 如果您的应用是放在 URL 根路径之外的地方(如在 /myapplication 中,不在 / 中),url_for() 会为您妥善处理。

例如,这里我们使用test_requests_cotext()方法来尝试使用url_for() 。test_request_context() 告诉 Flask 正在处理一个请求,而实际上也许我们正处在交互 Python shell 之中, 并没有真正的请求。

from flask import url_for

app = Flask(__name__)

@app.route('/')
def index():
    return 'index'

@app.route('/login')
def login():
    return 'login'

@app.route('/user/')
def profile(username):
    return f'{username}\'s profile'

with app.test_request_context():
    print(url_for('index'))
    print(url_for('login'))
    print(url_for('login', next='/'))
    print(url_for('profile', username='John Doe'))


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

告诉了请求的url,例如如果返回了index它的请求url为 http://127.0.0.1:5000/路由为
@app.route('/')

HTTP 方法

Web 应用使用不同的 HTTP 方法处理 URL 。当您使用 Flask 时,应当熟悉 HTTP 方法。 缺省情况下,一个路由只回应 GET 请求。 可以使用 route() 装饰器的 methods 参数来处理不同的 HTTP 方法:

from flask import url_for,request

app = Flask(__name__)

@app.route('/')
def index():
    return 'index'


def do_the_login():
    return 'post'


def show_the_login_form():
    return 'get'


@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'POST':
        return do_the_login()
    else:
        return show_the_login_form()


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

默认为get



如果当前使用了 GET 方法, Flask 会自动添加 HEAD 方法支持,并且同时还会 按照 HTTP_RFC 来处理 HEAD 请求。同样, OPTIONS 也会自动实现。

静态文件

动态的 web 应用也需要静态文件,一般是 CSS 和 JavaScript 文件。理想情况下您的 服务器已经配置好了为您的提供静态文件的服务。但是在开发过程中, Flask 也能做好 这项工作。只要在您的包或模块旁边创建一个名为 static 的文件夹就行了。 静态文件位于应用的 /static 中。

使用特定的 'static' 端点就可以生成相应的 URL

url_for('static', filename='test.css')

这个静态文件在文件系统中的位置应该是 static/test.css 。

渲染模板

使用render_template()方法可以渲染模板,您只要提供模板名称和需要 作为参数传递给模板的变量就行了。Flask 会在 templates 文件夹内寻找模板。

from flask import Flask , render_template


app = Flask(__name__)

@app.route('/tset/')
@app.route('/test/')
def hello(name=None):
    return render_template('main.html', name=name)


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

main.html必须放在这个文件中


 代码





HTLM 渲染



测试







 只要执行了hello函数,就会返回main.html文件,并可以传入相应的参数:


您可以充分使用 Jinja2 模板引擎的威力。

from flask import Flask , render_template


app = Flask(__name__)

@app.route('/tset/')
@app.route('/test/')
def hello(name=None):
    return render_template('main.html', name=name)


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



main.html改成:


Hello from Flask
{% if name %}

Hello {{ name }}!


{% else %}

Hello, World!


{% endif %}



如果
return render_template('main.html', name=name)  有name这这参数不管是否为空,就会执行

 如果没有name这个参数就会显示hello world