flask入门(二)

接着上文

讲一讲响应

flask调用视图函数后,会将其返回值作为响应的内容。大多数情况下,响应就是一个简单的字符串,作为HTML页面回送客户端。但HTTP协议需要的不仅是作为请求响应的字符串。HTTP响应中一个重要的部分是状态码,flask默认设为200,这个代码表明请求被成功处理。如果视图函数返回的响应需要使用不同的状态码,那么可以把数字代码作为第二个返回值,添加到响应文本之后。如下代码

@app.route('/wrong')
def wrong():
    return '<h1>Bad Rquest</h1>',400

启动服务后,在浏览器输入url还是能得到返回值的,

但是在cmd里可以看到

如果是正常的返回就是下面那个200,当然除了400外你可以设置成别的,还是会显示出来的

 有一种名为重定向的特殊响应类型,这种响应没有页面文档,只告诉浏览器一个新地址用以加载新页面,常用于表单中。常使用302状态码表示,指向的地址有location首部提供。重定向响应可以使用3个值形式的返回值生成,也可以在Response对象中设定。不过由于使用频繁,Flask提供了,redirect()的辅助函数,用于生成这种响应

from flask import redirect
@app.route('/')
def index():
    return redirect('http://www.example.com')

之后访问127.0.0.0:5000,他就会指向http://www.example.com/这个页面

上图来自《Flask Web开发:基于Python的Web应用开发实战(第2版)》

 之前我们用到的<h1>Hello World!</h1>就是一张jinja2模板,不过相对于return '<h1>Hello,%s !</h1>' %name这样返回name,jinja是这样的<h1>Hello, {{ name }}!</h1>

 之前那样的话有点不符合web开发,按道理应该是返回到文本的,我们可以先创建一个templates文件夹,在里面放入index.html和user.html。把上面两句话打进去,然后我们去修改hello.py

from flask import Flask,render_template

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

@app.route('/user/<name1>')
def user(name1):
    return render_template('user.html',name = name1)

保存,然后去访问,会发现得到的效果是一样的。

在user.html文件里有一个{{ name }},表示一种特殊的占位符,jinja2能识别所有类型的变量,甚至是一些复杂的类型,例如列表,字典和对象,如下

<p>A value from a dictionary: {{ mydict['key'] }}.</p>
<p>A value from a list: {{ mylist[3] }}.</p>
<p>A value from a list, with a variable index: {{ mylist[myintvar] }}.</p>
<p>A value from an object's method: {{ myobj.somemethod() }}.</p>

也可以用过滤器修改变量,过滤器名加载变量名之后,如Hello, {{ name|capitalize }},就是加了一个过滤器。

jinja变量过滤器有以下几个

完整的过滤器列表在这https://jinja.palletsprojects.com/en/2.10.x/templates/#builtin-filters

jinja提供了多种控制结构,举几个简单的例子,

条件控制

<ul>
   {% for comment in comments %}
     <li>{{ comment }}</li>
   {% endfor %}
</ul>

for循环

<ul>
     {% for comment in comments %}
         <li>{{ comment }}</li>
     {% endfor %}
</ul>    

还可以把需要重复使用的代码写入单独的文件,然后包含在模板用

{% include 'common.html' %}

当然还可以继承,

<html>
<head>
   {% block head %}
   <title>{% block title %}{% endblock %} - My Application</title>
   {% endblock %}
</head>
<body>
   {% block body %}
   {% endblock %}
</body>
</html>
{% extends "base.html" %} {% block title %}Index{% endblock %} {% block head %}
     {{ super() }}
     <style>
     </style>
{% endblock %} {% block body %}
<h1>Hello, World!</h1>
{% endblock %}

第一段代码就是基代码,第二段是继承之后的代码

说起来django用的应该也是jinja,我一直以为是django特色。。。。

然后用上面那些知识就可以自定义错误页面

@app.errorhandler(404)
def page_not_found(e):
     return render_template('404.html'), 404

@app.errorhandler(500)
def internal_server_error(e):
     return render_template('500.html'), 500

这样报错的话就会返回你指定的页面了

在定义动态路由链接的时候我们可以用url_for辅助函数。

他可以直接调用视图里的url,并在上面加上参数。如url_for('index')得到的结果应该是127.0.0.1:5000/如果加上点参数就是这样的url_for('index', page=3),返回结果是/?page=2。

当然还可以这样用('user', name='Red', _external=True),那么返回结果就是127.0.0.1:5000/user/Red这样的了。

原文地址:https://www.cnblogs.com/afei123/p/11291648.html