这两天稍微接触了一点 Flask 框架,所以分享点基础

1. 配置文件

from flask import Flask

app = Flask(__name__)
# 使用自定义的配置文件
app.config.from_object('settings.Config')
"""
# 内部原理 : con = 'settings.Config'
- a,b = con.rsplit('.',maxsplit=1) # 将字符分割
- m = importlib.import_module(a) # 导入settings模块
- class = getattr(m.b) # 拿到settings下的类
""" @app.route('/index')
def index(): return 'index' if __name__ == '__main__':
# print(app.config) # 打印 Flask 下的配置属性
app.run() ################### 配置文件.py #################### class Config(object):
DEBUG = False class ProductionConfig(Config): # 线上环境使用的配置
DEBUG = False class DevelopmentConfig(Config): # 开发环境下使用
DEBUG = True

2. 路由系统

from flask import Flask,render_template,request,redirect,session,url_for

app = Flask(__name__)

"""
endpoint=名字
这个名字就指代了当前视图函数的 url 地址 如果不写 endpoint 那么 url_for 反向解析的默认值就是当前视图函数的名字
- url_for('index')
""" # @app.route('/index',methods=['GET','POST'],endpoint='q1')
@app.route('/index/<int:nid>',methods=['GET','POST'])
def index(nid):
"""
nid -- 接收上面 url 中的参数
接收参数类型:
- @app.route('/index<username>') # 字符
- @app.route('/index<int:nid>') # 整数
- @app.route('/index<float:nid>') # 浮点
- @app.route('/index<path:path>') # 路径
:param nid:
:return:
"""
# print(url_for('q1')) # 反向解析 url : /index
# print(url_for('index')) # 默认 函数名 : /index
# print(url_for('index',nid=333)) # /index/333
return 'INDEX' if __name__ == '__main__':
app.run()

3. 请求和响应

from flask import Flask, render_template, request, redirect, session, url_for, jsonify, make_response

app = Flask(__name__)

@app.route('/index', methods=['GET', 'POST'])
def index():
"""
常用 响应方式
return 'INDEX'
return jsonify({'k1':k2})
return render_template()
return redirect()
:return:
"""
# 设置响应头
obj = make_response('Index') # 把要返回的字符串,封装到对象中
obj.headers['headers_q'] = 'xxx'
obj.set_cookie('k1','v1')
return obj if __name__ == '__main__':
app.run()

4. 模板

"""

    模板渲染:
- 1. 标签解析:
方式一:{{txt|safe}}
方式二:MarpUp -- Markup("<input type='text' />")
- 2. 在模板进行函数调用
方式一:自定义一个函数,然后变成参数传递 -- {{fn(7)}}
方式二:使用 @app.template_global() 来定义一个全局的函数,在所有模板都可用(加括号) -- {{fn1(1,2)}}
方式二:使用 @app.template_filter() 来定义一个全局的函数,在所有模板都可用(加括号) -- {{4|fn2(6,7)}}
- 3. 模板继承:
- 父模板:{% block content %} {% endblock %}
- 子模版:{% extends 'base.html' %}
{% block content %}
{% endblock %} - 4. 在模块中定义 宏
{% macro a(name,type='text',value='') %}
<h1>宏</h1>
<input type="{{type}}" name="{{name}}" value="{{value}}">
{% endmacro %}
{{a('q')}}
"""
from flask import Flask,render_template,request,redirect,session,url_for,jsonify,make_response,Markup,flash,get_flashed_messages app = Flask(__name__) # 全局函数(加括号) - 可以任何模板中使用
@app.template_global()
def fn1(a1,a2):
return a1+a2 # 参数放的方式不一样,可以用于判断条件
@app.template_filter()
def fn2(a1,a2,a3):
return a1+a2+a3 def fn(arg):
return arg @app.route('/index',methods=["GET","POST"])
def index():
print('index')
info = {
'lis':[1,2,3],
'txt':"<input type='text' />",
'txt1':Markup("<input type='text' />"),
'fn':fn
}
return render_template('models.html',**info) if __name__ == '__main__':
app.run()

5. session 简单了解

"""
# 当请求刚到来的时:flask 读取cookie 中对应的值,将值解密,并放反序列化成字典,放入内存,以便视图函数使用
# 当请求结束时,flask 会读取内存中字典的值,进行序列化和加密,写入 Cookie 中 - 只能取一次 session 值:
from flask import Falsk, flash, get_fiashed_messages flash('k1') -- 存放一个值到 session 中
- 可以分类:
flash('k1','error')
flash('k2','error')
flash('k3','info')
get_flashed_messages() -- 只能获取一次 session 的值
- 可以只拿分类中的数据
get_flashed_messages(category_filter=['error'])
"""

6. 特殊装饰器 -- 类似于 Django 中的中间件

from flask import Flask
app = Flask(__name__) """
执行顺序:
1. before -> Index -> after
2. before1 -> before2 -> Index -> after2 -> after1
3. before1(如果return) --> after2 -> after1 定制错误页面:
@app.errorhandler(404)
def not_found(arg):
return xxx.html """ @app.before_request
def x1():
print('before') @app.after_request
def x2(response):
print('after')
return response @app.route('/index')
def index():
print('index')
return 'Index' if __name__ == '__main__':
app.run()

7. 中间件

"""
- call 触发条件:
- 用户发起请求时执行
"""
from flask import Flask
app = Flask(__name__) class Middleware(object):
def __init__(self,old):
self.old = old def __call__(self, *args, **kwargs):
ret = self.old(*args, **kwargs)
return ret if __name__ == '__main__':
app.wsgi_app = Middleware(app.wsgi_app)
app.run()

持续更新...

python - Flask 基础(1)的更多相关文章

  1. python flask 基础入门

    1. Flask 中的Hello World! 在使用pycharm创建一个Flask项目后,将会默认创建一个flask的app,这里来讲下每行代码表示的意义,代码入下 from flask impo ...

  2. python - Flask 基础 - 蓝图( Blueprint )(2)

    """ 蓝图:为开发者提供的目录结构 - 使用: 1. 根目录创建一个跟项目名一样的文件 - 创建后第一步,在这个文件夹中添加一个 __init__.py 的配置文件 - ...

  3. 知了课堂 Python Flask零基础 笔记整理

    目录 起步 安装Python2.7: Python虚拟环境介绍与安装: pip安装flask: 认识url: URL详解 web服务器和应用服务器以及web应用框架: Flask 第一个flask程序 ...

  4. [Python][flask][flask-login]关于flask-login中各种API使用实例

    本篇博文跟上一篇[Python][flask][flask-wtf]关于flask-wtf中API使用实例教程有莫大的关系. 简介:Flask-Login 为 Flask 提供了用户会话管理.它处理了 ...

  5. python Flask

    python Flask Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请 ...

  6. Python Flask Restful

    Flask  Restful 1.flask restful 在flask基础上进行一些封装,主要用于实现restful接口 2.restful的理解 1)URI(统一资源标识符):每一个URI代表一 ...

  7. Python+Flask+MysqL的web建设技术过程

    一.前言(个人学期总结) 个人总结一下这学期对于Python+Flask+MysqL的web建设技术过程的学习体会,Flask小辣椒框架相对于其他框架而言,更加稳定,不会有莫名其妙的错误,容错性强,运 ...

  8. flask基础之jijia2模板语言进阶(三)

    前言 前面学习了jijia2模板语言的一些基础知识,接下来继续深挖jijia2语言的用法. 系列文章 flask基础之安装和使用入门(一) flask基础之jijia2模板使用基础(二) 控制语句 和 ...

  9. flask基础之jijia2模板使用基础(二)

    前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...

随机推荐

  1. stl 自定义排序与删除重复元素

    转: STL—vector删除重复元素 STL提供了很多实用的算法,这里主要讲解sort和unique算法. 删除重复元素,首先将vector排序. sort( vecSrc.begin(), vec ...

  2. SQL Server 数据库清空ldf日志文件

    USE [master] ALTER DATABASE [DB_Develop] SET RECOVERY SIMPLE WITH NO_WAIT ALTER DATABASE [DB_Develop ...

  3. STM32之spi管理模式

    1)sip管理模式分为:硬件管理和软件管理:主要由NSS .SSI.SSM决定: NSS是芯片上一个实实在在的引脚,SSI和SSM是SPI_CR1控制器里的的位. 值得注意的是:NSS分外部引脚和内部 ...

  4. C++Primer 5th Chap10 Generic Algorithms(未完)

    大多数算法定义在头文件algorithm中,在头文件numeric中定义了数值泛型算法. 以find算法为例:在容器的两个迭代器指定的范围内遍历,查找特定值. auto result= cout< ...

  5. TCP/IP协议图--TCP/IP基础

    1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为 TCP/IP 是指 TCP 和 IP 两种协议.实际生活当中有时也确实就是指这两种协议.然而在很多情况下,它只是利用 IP 进行通信时所 ...

  6. 20191106-基于Python的对字母基数排序

    基数排序 概念 基数排序的算法过程是先将待排元素补位,使其长度一致,然后按照序列中的元素的每个位数进行分桶的一种算法. 比如待排序列是数字,则将所有待比较数值(正整数)统一为同样的数位长度,数位较短的 ...

  7. 为什么无人机测量主流现在都不用RTK技术,而是PPK技术【转】

    为什么无人机测量主流现在都不用RTK技术,而是PPK技术_宇辰网_让世界读懂无人机_全球专业无人机资讯|电商|大数据服务平台 大疆Phantom 4 RTK正式发布_宇辰网_让世界读懂无人机_全球专业 ...

  8. RabbitMQ消息队列入门(一)——RabbitMQ消息队列的安装(Windows环境下)

    一.RabbitMQ介绍1.RabbitMQ简介RabbitMQ是一个消息代理:它接受和转发消息.你可以把它想象成一个邮局:当你把你想要发布的邮件放在邮箱中时,你可以确定邮差先生最终将邮件发送给你的收 ...

  9. 90% 的 Python 开发者不知道的描述符应用

    经过上面的讲解,我们已经知道如何定义描述符,且明白了描述符是如何工作的. 正常人所见过的描述符的用法就是上篇文章提到的那些,我想说的是那只是描述符协议最常见的应用之一,或许你还不知道,其实有很多 Py ...

  10. 【转载】C#中使用OrderBy和ThenBy等方法对List集合进行排序

    在C#的List操作中,针对List对象集合的排序我们可以使用OrderBy.OrderByDescending.ThenBy.ThenByDescending等方法按照特定的对象属性进行排序,其中O ...