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 "<p>Hello, World!</p>" if __name__ == '__main__': app.run()
运行结果:点击运行下面的连接就能看到右边入图的网页结果
-
首先我们导入了 Flask 类。该类的实例将会成为我们的 WSGI 应用。
-
接着我们创建一个该类的实例。第一个参数是应用模块或者包的名称。
__name__是一个适用于大多数情况的快捷方式。有了这个参数, Flask 才能知道在哪里可以找到模板和静态文件等东西。 -
然后我们使用 route() 装饰器来告诉 Flask 触发函数 的 URL 。
-
函数返回需要在用户浏览器中显示的信息。默认的内容类型是 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("/<name>")
def hello(name):
return f"Hello, {escape(name)}!"
if __name__ == '__main__':
app.run()
可以看到它会把http://127.0.0.1:5000/ <name> 把参数写到html中
记得:只要关闭了app.py 的运行网页就没无法访问
路由
现代 web 应用都使用有意义的 URL ,这样有助于用户记忆,网页会更得到用户的青睐, 提高回头率。
使用 route()装饰器来把函数绑定到 URL:
from flask import Flask app = Flask(__name__) # 路由用来匹配url,在这个url下的函数 @app.route('/') def hello_world(): return "<p>Hello, World!</p>" # 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 的一部分标记为 <variable_name> 就可以在 URL 中添加变量。标记的 部分会作为关键字参数传递给函数。通过使用 <converter:variable_name> ,可以 选择性的加上一个转换器,为变量指定规则。
from flask import Flask from markupsafe import escape app = Flask(__name__) # 路由用来匹配url,在这个url下的函数 @app.route('/') def hello_world(): return "<p>Hello, World!</p>" from markupsafe import escape @app.route('/test/<username>') def show_user_profile(username): if 1 == username: return f'{escape(username)},是一个整数' if '1' == username: return f'{escape(username)},是字符串'
可以看到url的值默认是字串,可以指定为其它类型
把路由器改成
@app.route('/test/<int:username>')

同理:
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()动态构建?
-
反转通常比硬编码 URL 的描述性更好。
-
您可以只在一个地方改变 URL ,而不用到处乱找。
-
URL 创建会为您处理特殊字符的转义,比较直观。
-
生产的路径总是绝对路径,可以避免相对路径产生副作用。
-
如果您的应用是放在 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/<username>') 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/<name>') def hello(name=None): return render_template('main.html', name=name) if __name__ == '__main__': app.run()
main.html必须放在这个文件中
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>HTLM 渲染</title>
</head>
<body>
<h1> 测试 </h1>
</body>
</html>
只要执行了hello函数,就会返回main.html文件,并可以传入相应的参数:
您可以充分使用 Jinja2 模板引擎的威力。
from flask import Flask , render_template app = Flask(__name__) @app.route('/tset/') @app.route('/test/<name>') def hello(name=None): return render_template('main.html', name=name) if __name__ == '__main__': app.run()
main.html改成:
<!doctype html>
<title>Hello from Flask</title>
{% if name %}
<h1>Hello {{ name }}!</h1>
{% else %}
<h1>Hello, World!</h1>
{% endif %}
如果
return render_template('main.html', name=name) 有name这这参数不管是否为空,就会执行

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






浙公网安备 33010602011771号