Flask的模板渲染:

Flask的模板在进行渲染的时候是默认选则templates下的html文件 我们可以在实例化app的时候,指定文件来进行选择:

模板渲染更改文件夹:template_folder = 要指定的文件夹

app = Flask(__name__,template_folder="templ")  # 把你的指定html模板改为templ文件夹下

static_folder 是指定你的静态文件指定的文件夹,static_url_path 是你的前端界面访问的地址

app = Flask(__name__,template_folder="templ",static_folder = "statics",static_url_path="/app")# 实例化一个flask对象   static_folder 指定你的静态文件的读取存放的文件夹  ,static_url_path 是你的前端界面访问的名称要一致

 ststic_folder是指定静态文件的路径 

static_url_path是指定你静态文件的访问url

何为蓝图 其实就是展开设计 进行更多的设计,说白了就是对你的app中的内容进行扩展

它的作用就是将 功能与主服务分开。

我们可以在你的蓝图中新增功能,然后在你的主功能区中对你的蓝图进行导入 然后你的主功能区就有了你的蓝图的功能

蓝图文件内:

from flask import Blueprint,render_template,request  #Blueprint是你的蓝图模块
addstu = Blueprint( # 实例化蓝图对象
"addstu",__name__, # 这个addstu的名字可以是随便起的 主要是为了让我们方便阅读与查看
template_folder="../addtempl",
static_folder="../statics",
static_url_path="/statics") # 蓝图的文件读取设置 @addstu.route("/add_stu/",methods = ["GET","POST"]) # 也是路由分发
def add_stu():
if request.method == "GET":
return render_template("add.html")

然后在你的主功能区先导入你的蓝图的文件:

from seve import add_stu  #导入你的文件

导入你的蓝图:app.register_blueprint("蓝图文件")

app.register_blueprint(add_stu.addstu)  # 导入你的蓝图add_stu.addstu

如果你要访问你的 蓝图中的函数  ,然后的你的ur后面跟着的就是你的蓝图内路由分发的url就是:

http://127.0.0.1:9768/add_stu/  # 蓝图中的地址

切记:你的蓝图实例化的对象和蓝图中的函数名不可相同

其实我们可以把蓝图来理解为django中我们创建的一个个的app

请求拓展:(类似于Django的中间件)

Flask的中间件:

@app.before_request 程序执行其他函数的时候先走里进行判断

每一次先执行其他的函数的时候都会先执行这个进行判断 就好比django的中间件进行校验

@app.before_request
def once():
print("这个是程序执行的时候")
if request.path == "/login/": # l类似于中间件的白名单
return None
# user = session.get("user")
if session.get("user"):
return None else:
return redirect("/login/")

@app.after_request 你的flask结束的时候要走它  所有的结束之后要经过after_request再渲染到界面

@app.after_request
def after_re(response):
print("现在我要出去了")
return response

执行流程:

这个是程序执行的时候
现在我要出去了
这个是程序执行的时候
127.0.0.1 - - [06/Sep/2018 20:16:39] "GET /login/ HTTP/1.1" 200 -
现在我要出去了

就是你的每一个请求都会先走before_request 然后结束之前都会走after_request 这个就是Flask的中间件可以分开只有before_request 或者after_request

after_request的执行结果和Django的1.7之前的一样 如果出错 或者想出去会从最下面开始先执行,

@app.before_request
def once():
print("这个是程序执行的时候")
if request.path == "/login/": # l类似于中间件的白名单
return None
# user = session.get("user")
if session.get("user"):
return None
else:
return redirect("/login/") @app.after_request #最后在执行这个
def after_re(response):
print("现在我要出去了")
return response @app.after_request #当结束的时候先执行这个 因为它在最下面
def after_ll(response):
print("现在我才是第一个要出去的")

定制错误信息: @ app.errorhandler()

当你的错误的时候就可以这样来定制了页面

@ app.errorhandler(110)
def error_404(arg):
return "页面找不到"

闪现 : flash :

本质:flash是基于session创建的,flash支持往里边放值,只要你取一下就没有了,相当于pop了一下。不仅吧值取走,而且吧session里的东西去掉

from flask import Flask,session,Session,flash,get_flashed_messages

 v = get_flashed_messages()  #取值清空你的闪现中存放的值

Falsk的模板分配和蓝图、定制错误信息、 和补充的更多相关文章

  1. ThinkPHP第八天(U函数放置在外部JS不会被解析,错误界面定制,错误信息变量)

    1.JS外部文件中U函数不会被解析,内部JS代码可以被解析. 2.halt. _404可以定制错误模板,在配置文件中配置 TMPL_EXCEPTION_FILE =>'./Public/Tpl/ ...

  2. Django-Form表单(验证、定制、错误信息、Select)

      Django form 流程 1.创建类,继承form.Form 2.页面根据类的对象自动创建html标签 3.提交,request.POST       封装到类的对象里,obj=UserInf ...

  3. thinkphp 定制错误页面

    在前台配置文件里加上: 'TMPL_EXCEPTION_FILE' => '.Public/tpl/error.html',// 异常cuowu页面的模板文件 然后在Public下新建一个tpl ...

  4. ruby -- 进阶学习(九)定制错误跳转404和500

    在开发阶段,如果发生错误时,都会出现错误提示页面,比如:RecordNotFound之类的,虽然这些错误方便开发进行debug,但是等产品上线时,如果还是出现这些页面,对于用户来说是很不友好的. 所以 ...

  5. SpringBoot定制错误的Json数据

    (1)自定义异常处理&返回定制Json数据 @ControllerAdvice public class MyExceptionHandler { @ResponseBody @Excepti ...

  6. SpringBoot定制错误页面

    (1)有模板引擎的情况下,例如404错误,将会在thymeleaf的templates的error下寻找404.html,如果找不到再寻找4xx.html *所有4开头的错误状态码如果找不到特定的ht ...

  7. springboot 定制错误页面

    项目中经常遇到的异常情况 400-Bad Request 401-Unauthorized If the request already included Authorization credenti ...

  8. 【Laravel5】 定制错误页面

    laravel5   所有异常错误都由类   App\Exceptions\Handler    处理,该类包含两个方法:   report   和   render . 这里我们只看 render  ...

  9. Spring boot错误处理以及定制错误页面

    如果是浏览器访问,返回错误页面 注意浏览器发送请求的请求头:  注意区别其他客户端哦比如 postman 如果是其他客户端,返回一个Json数据 原理可以参照ErrorMvcAutoConfigura ...

随机推荐

  1. web前端之JavaScript

    JavaScript概述 JavaScript历史 在上个世纪的1995年,当时的网景公司正凭借其Navigator浏览器成为Web时代开启时最著名的第一代互联网公司.由于网景公司希望能在静态HTML ...

  2. 数据库学习---SQL基础(二)

    数据库学习---SQL基础(一) 数据库学习---SQL基础(二) 数据库学习---SQL基础(三) 上篇复习的sql的增删改查,and ,or ,>=, <=,!=等逻辑运算符,还有in ...

  3. php的一个验证邮箱的正则表达式

    /([a-z0-9]*[-_\.]*[a-z0-9]+)*[-_\.]*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.]([a-z0-9]{2,3}|[a-z0-9]*[-_]?[a-z ...

  4. java.io.Serializable的作用

    Serializable,之前一直有使用,默认的实体类就会实现Serializable接口,对具体原因一直不是很了解,同时如果没有实现序列化,同样没什么影响,什么时候应该进行序列化操作呢?今天查了下资 ...

  5. JBoss Web和Tomcat的区别

    在Web2.0的时代,基于Tomcat内核的JBoss在J2EE应用服务器领域已成为发展最为迅速的应用服务器.这一青出于蓝而胜于蓝的产品与Tomcat的区别又在哪里? 基于Tomcat内核,青胜于蓝. ...

  6. onkeydown事件

    <img src="images/hot.jpg" alt="" id="imgId" class="img1"/ ...

  7. Android开发关闭虚拟按钮、底部导航条

    在Android开发中,遇到了一系列大大小小的问题,其中一个就是屏蔽底部实体键,我找了很多的博客也尝试了许许多多的方法,但始终不能屏蔽 HOME键,后来看见一篇博客说在Android 4.0以后,屏蔽 ...

  8. kafka 启动 报错cannot allocate memory,即内存不足

    错误提示: Java Hotspot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c5330000, 9865134 ...

  9. [转]iCheck表单美化插件使用方法详解(含参数、事件等)

    本文转自:http://www.exp99.com/jswz/f2e/1408696007_34.html iCheck   特色: 1.在不同浏览器(包括ie6+)和设备上都有相同的表现 — 包括 ...

  10. 打造自己的LinQProvider(四)

    打造自己的LinqProvider *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...