1.endpoint参数,解决视图函数重名问题(包括装饰后重名问题)

  http://www.cnblogs.com/eric-nirnava/p/endpoint.html

  • 每个应用程序app都有一个view_functions,这是一个字典,存储endpoint-view_func键值对。add_url_rule的第一个作用就是向view_functions中添加键值对(这件事在应用程序run之前就做好了)
  • 每个应用程序app都有一个url_map,它是一个Map类(具体实现在werkzeug/routing.py中),里面包含了一个列表,列表元素是Role的实例(werkzeug/routing.py中)。add_url_rule的第二个作用就是向url_map中添加Role的实例(它也是在应用程序run之前就做好了)
    {'static': <bound method _PackageBoundObject.send_static_file of <Flask 'myflask'>>, 'add.add': <function stu_add at 0x000000000399F0D0>, 'update.update': <function stu_update at 0x0000000003AC8730>, 'delete.delete': <function stu_delete at 0x0000000003AC8840>, 'reg.reg': <function View.as_view.<locals>.view at 0x0000000003934620>, 'hello_world': <function hello_world at 0x0000000003B1EA60>, 'login': <function login at 0x0000000003B1EAE8>, 'student_list': <function student_list at 0x0000000003B1EBF8>}
    Map([<Rule '/login' (POST, OPTIONS, GET, HEAD) -> login>,
    <Rule '/list' (POST, OPTIONS, GET, HEAD) -> student_list>,
    <Rule '/add' (POST, OPTIONS, GET, HEAD) -> add.add>,
    <Rule '/reg' (POST, OPTIONS, GET, HEAD) -> reg.reg>,
    <Rule '/' (OPTIONS, GET, HEAD) -> hello_world>,
    <Rule '/update/<sid>' (POST, OPTIONS, GET, HEAD) -> update.update>,
    <Rule '/delete/<sid>' (POST, OPTIONS, GET, HEAD) -> delete.delete>,
    <Rule '/static/<filename>' (OPTIONS, GET, HEAD) -> static>])

2.Flask中的路由配置

  @app.route("/<int:age>",methods=("get",),endpoint='xxx')
  动态路由参数<age>

3.Flask的配置

  1) Flask的实例配置
    app.config.from_object(obj)
    class Obj:

      DEBUG=True,。。。、、

  2) Flask初始化配置
    app=Flask(__name__,template_folder.....)
    template_folder = "模板存放路径"  # 蓝图应用时在蓝图py文件在同一文件夹下
      static_folder = "静态文件存放路径"
    static_url_path = "/默认值是等于static_folder的名字" # 蓝图应用时path不能重复
    static_host .....

4.蓝图(Blueprint)
  

  bp = Blueprint("bulename",__name__)   # 与Flask实例一样传参  

  @bp.route("/") 为蓝图添加路由 方式与Flask实例路由一毛一样

  注册蓝图
  app.register_blueprint(bule.bp)

插拔机制

5.装饰器before_request、aftert_request、errorhandler(404)
  

@app.before_request 请求进入视图函数之前作出处理
@app.after_request 请求结束视图函数之后,返回客户端之前,作出处理
def after(response)
return response

be1-be2-af2-af1
be1-af2-af1

errorhandler(404) #定义错误请求的响应
def err(code_or_exp)
  

@app.errorhandler(404)
def errors(code_or_exception):
# print(dir(arg),arg.name,arg.get_description())
return redirect("/login") # app.add_url_rule("/bo/<age>", methods=("GET", "POST"),endpoint="bofunc")

errorhandler

6.skip闪现(flash)

@app.route("/index")
def index():
res = get_flashed_messages()
if not res:
res = [""]
flash("你刚才访问了index")
return render_template("index.html",msg=res[0]) @app.route("/home")
def index1():
res = get_flashed_messages()
if not res:
res = [""]
flash("你刚才访问了home")
return render_template("index.html",msg=res[0]) if __name__ == '__main__':
app.run()

flash

7.sendfile jsonify
  

1.form flask import send_file
flask send_file 打开文件并返回
send_file(文件路径)

2.from flask import jsonify
return jsonify({a:1})
打包一个 content-Type:application/json 返回给客户端
jsonify的配置在app["JSONIFY_MIMETYPE"] = ""

python全栈开发day111-flask路由及其参数,Flask配置,蓝图,几个装饰器、闪现、send_file、jsonify的更多相关文章

  1. python 全栈开发,Day120(路由系统, 实例化Flask的参数, 蓝图(BluePrint), before_request after_request)

    昨日内容回顾 1.Flask: from flask import Flask app = Flask(__name__) # 从源码中可以看出,Flask集成的run方法是由werkzeug中的ru ...

  2. python 全栈开发,Day89(sorted面试题,Pycharm配置支持vue语法,Vue基础语法,小清单练习)

    一.sorted面试题 面试题: [11, 33, 4, 2, 11, 4, 9, 2] 去重并保持原来的顺序 答案1: list1 = [11, 33, 4, 2, 11, 4, 9, 2] ret ...

  3. python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)

    昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...

  4. python全栈开发目录

    python全栈开发目录 Linux系列 python基础 前端~HTML~CSS~JavaScript~JQuery~Vue web框架们~Django~Flask~Tornado 数据库们~MyS ...

  5. Python 全栈开发【第0篇】:目录

    Python 全栈开发[第0篇]:目录   第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...

  6. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  7. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  8. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  9. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  10. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

随机推荐

  1. bootstrapValidator操作

    1.html中表单初始化 <script> //表单验证初始化 $('#wx_pay_account_form_id').bootstrapValidator({ message : 'T ...

  2. 「HGOI#2019.4.19省选模拟赛」赛后总结

    t1-Painting 这道题目比较简单,但是我比较弱就只是写了一个链表合并和区间DP. 别人的贪心吊打我的DP,嘤嘤嘤. #include <bits/stdc++.h> #define ...

  3. Codeforces Gym 101252D&&floyd判圈算法学习笔记

    一句话题意:x0=1,xi+1=(Axi+xi%B)%C,如果x序列中存在最早的两个相同的元素,输出第二次出现的位置,若在2e7内无解则输出-1. 题解:都不到100天就AFO了才来学这floyd判圈 ...

  4. 插入mysql失败,因为java数据类型是个实体类,加上.id就好了

    错误信息: ### Error updating database. Cause: java.sql.SQLException: Incorrect string value: '\xAC\xED\x ...

  5. Java入门:基础算法之二进制转换为十进制

    Java有两种方法可以将二进制数转换为十进制数: 1)使用Integer类的Integer.parseInt()方法. 2)自己编写转换逻辑. 方法1:使用Integer.parseInt()实现二进 ...

  6. JavaProperties类、序列化流与反序列化流、打印流、commons-IO整理

    Properties类 Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载.属性列表中每个键及其对应值都是一个字符串. 特点: 1.Hashtable的子类 ...

  7. Numpy系列(十三)- 文件IO

    NumPy提供了多种存取数组内容的文件操作函数.保存数组数据的文件可以是二进制格式或者文本格式.二进制格式的文件又分为NumPy专用的格式化二进制类型和无格式类型. 一,tofile()和fromfi ...

  8. MySQL_关于索引空间的的一些记录

    一.清理普通索引占用的空间 问:对表中存在的k列(非主键)的普通索引执行以下重建操作,有什么影响? alter table T drop index k; alter table T add inde ...

  9. ubuntu14.04 网络配置

    流程分析: 在Ubuntu系统网络设备启动的流程中,会依赖/etc/network/interface的配置文件初始化网络接口,所以直接在/etc/network/interface之中配置好对应的d ...

  10. .net异步委托

    委托Delegate是一个类,定义了方法的类型, 使得可以将方法当做另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,可以避免在程序中大佬使用If-Else(Switch)语句,同时使得程序 ...