Flask之基础、g对象和信号

一、简介

1、flask简介

Flask是python一款小二精的轻量级Web框架,默认依赖于jinja2模版引擎和WSGI工具集--Werkzeug。虽然flask只保留了WEB开发的核心功能,没有Django的功能全,但是,它可以用第三方插件进行功能扩展,比如数据库可以使用Flask-SQLAlchemy,缓存可以使用Flask-Cache等

特点:灵活性可拓展性强,对各种数据库的契合度都较高,小项目开发快,大项目设计灵活

2、werkzeug简介

Werkzeug:定位是Http和WSGI相关工具集,可以作为web框架的底层库,提供了路由处理、request和response封装、自带的WSGI server等功能,它在flask中负责核心的逻辑模块像路由、请求和应答的封装、以及WSGI相关的函数等

3、jinja2简介

jinja是python的一个模版引擎,类似Django的DTL,功能也很丰富,支持 unicode 解析、自动 HTML escape 、防止 XSS 攻击、继承、变量、过滤器、流程逻辑支持、python 代码逻辑集成等等

二、flask的快速使用

1、flask的创建使用

(1)目录结构

 

"""
├── Flask01
    ├── static/             # 用来存放静态文件
    ├── templates/      # 用来存放html模板文件
    └── app.py            # 程序文件
"""

 

(2)app.py例子代码

from flask import Flask,request

app=Flask(__name__)

@app.route('/')   # 装饰器加括号和不加括号的区别
def index():
    # 当前请求地址,当前请求携带过来的数据
    print(request.path)
    return 'hello world'

@app.route('/hello')
def hello():
    print(request.path)
    return 'hello hellohello'
if __name__ == '__main__':
    app.run()
    

(3)运行,只需右键运行app.py文件即可

2、Debug模式

(1)debug模式默认是关闭的,开启debug模式后,每次修改完代码,只需要保存一下,就会自动重启flask项目,不需要手动去重启。

(2)debug开启的四种方式

# 第一种,直接在app的run方法中设置
from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello():
    return "hello"

if __name__ == '__main__':
    app.run(debug=True)  # 设置

# 第二种
from flask import Flask
app = Flask(__name__)
app.debug = True  # 设置

#第三种,利用config的本质是字典
from flask import Flask
app = Flask(__name__)
#可以用以下两个其中一个
app.config['DEBUG'] = True
#app.config.update(DEBUG=True)  # config本质是字典

# 第四种,加载配置文件
from flask import Flask
import config  # 导入
app = Flask(__name__)
app.config.from_object(settings)  # 设置
# --------- settings.py 内容---------
DEBUG = True

3、获取前端传过来的数据

# get 请求
request.query_string
# post 请求
user = request.form.get('user')
pwd = request.form

4、配置文件

(1)直接对app的config进行更改

app.config['DEBUG'] = True

(2)通过py文件配置

app.config.from_pyfile('自己创建的配置文件名字')

(3)通过类配置

app.config.from_object('settings.TestingConfig')

# ---------settings.py文件下的类------------
class Config(object):
    DEBUG = False
    TESTING = False
    DATABASE_URI = 'sqlite://:memory:'

class TestingConfig(Config):
    TESTING = True

5、路由

# route(路径(转换器),请求方法,别名)
@app.route('/detail/<int:nid>',methods=['GET'],endpoint='detail')
'''
endpoint:类似django的方向解析,不写默认是函数名,endpoint之间不能重名
<int:nid>跟Django的转换器一样
# ----------- 转换器 ------------
default :  UnicodeConverter  (默认使用)
  string  :  UnicodeConverter
  any      :  AnyConverter
  path    :  PathConverter
  int     :  IntegerConverter
  float   :  FloatConverter
  uuid    :  UUIDConverter
'''

 6、CVB

from flask import Flask,request,render_template,redirect
from flask import views
app=Flask(__name__)
#装饰器
def auth(func):
    def inner(*args, **kwargs):
        print('before')
        result = func(*args, **kwargs)
        print('after')
        return result
    return inner
class IndexView(views.MethodView):
    methods = ['GET']  # 指定运行的请求方法
    # 登录认证装饰器可以加在这里
    decorators = [auth, ]  #加多个就是从上往下的效果
    def get(self):
        print('xxxxx')
        return "我是get请求"
    def post(self):
       return '我是post请求'
# 路由注册:注意:as_view方法必须传参数name,name相当于endpoint
app.add_url_rule('/index',view_func=IndexView.as_view('index'))

if __name__ == '__main__':
    app.run()

 三、g对象

本质:g对象是一个全局变量,用来存储当前请求的用户信息,重新发起请求后,g对象也会跟着改变

使用方法:

from flask import Flask,g

app=Flask(__name__)

@app.before_request
def test():
    # 给g对象赋值
    g.name='测试'
'''
当我们需要在request请求中存东西的时候,尽量用g对象代替,避免出现错误
'''
@app.route('/')
def home():
    return g.name

if __name__=='__main__':
    app.run()

四、信号

1、概述

flask框架的信号是基于blinker,主要是为了方便开发者在flask 请求过程中定制一些功能代码

注意,需要安装blinker库:pip install blinker

2、flask内置的信号

request_started = _signals.signal('request-started')                # 请求到来前执行
request_finished = _signals.signal('request-finished')              # 请求结束后执行
 
before_render_template = _signals.signal('before-render-template')  # 模板渲染前执行
template_rendered = _signals.signal('template-rendered')            # 模板渲染后执行
 
got_request_exception = _signals.signal('got-request-exception')    # 请求执行出现异常时执行
 
request_tearing_down = _signals.signal('request-tearing-down')      # 请求执行完毕后自动执行(无论成功与否)
appcontext_tearing_down = _signals.signal('appcontext-tearing-down')# 应用上下文执行完毕后自动执行(无论成功与否)
 
appcontext_pushed = _signals.signal('appcontext-pushed')            # 应用上下文push时执行
appcontext_popped = _signals.signal('appcontext-popped')            # 应用上下文pop时执行
message_flashed = _signals.signal('message-flashed')                # 调用flask在其中添加数据时,自动触发

3、信号的使用

from flask import Flask,g,signals

app=Flask(__name__)

@app.route('/')
def home():
    return '信号量的使用'

def func(*args,**kwargs):
    print('触发信号',args,kwargs)
    
# 将函数注册到flask的内置信号request_started中
# 当发起请求的时候,就会触发该信号,进而执行该函数
signals.request_started.connect(func)

if __name__=='__main__':
    app.run(debug=True)

4、自定义信号

# -*-coding:utf-8 -*-
from flask import Flask,signals

app=Flask(__name__)
#1、 定义一个信号
my_signal=signals._signals.signal('my_signal')

def func(*args,**kwargs):
    print('触发自定义信号',args,kwargs)
# 2、将func函数跟自定义信号进行绑定
my_signal.connect(func)
@app.route('/index')
def index():
    #3、 触发信号
    my_signal.send(123,k='信号')
    return '触发自定义信号'

if __name__=='__main__':
    app.run()

原文地址:https://www.cnblogs.com/nq31/p/14311059.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Jinja2:是Python的Web项目中被广泛应用的模板引擎,是由Python实现的模板语言,Jinja2 的作者也是 Flask 的作者。他的设计思想来源于Django的模板引擎,并扩展了其语法和一系列强大的功能,其是Flask内置的模板语言。
Fullcalendar日历使用,包括视图选择、事件插入、编辑事件、事件状态更改、事件添加和删除、事件拖动调整,自定义头部,加入el-popover显示图片、图片预览、添加附件链接等,支持手机显示。
监听QQ消息并不需要我们写代码,因为市面上已经有很多开源QQ机器人框架,在这里我们使用go-cqhttp官方文档:go-cqhttp如果您感兴趣的话,可以阅读一下官方文档,如果不想看,直接看我的文章即可。
【Flask框架】—— 视图和URL总结
python+web+flask轻量级框架的实战小项目。登录功能,后续功能可自行丰富。
有了这个就可以配置可信IP,关键是不需要企业认证,个人信息就可以做。
本专栏是对Flask官方文档中个人博客搭建进行的归纳总结,与官方文档结合事半功倍。 本人经验,学习一门语言或框架时,请首先阅读官方文档。学习完毕后,再看其他相关文章(如本系列文章),才是正确的学习道路。
本专栏是对Flask官方文档中个人博客搭建进行的归纳总结,与官方文档结合事半功倍。基础薄弱的同学请戳Flask官方文档教程 本人经验,学习一门语言或框架时,请首先阅读官方文档。学习完毕后,再看其他相关文章(如本系列文章),才是正确的学习道路。 如果python都完全不熟悉,一定不要着急学习框架,请首先学习python官方文档,一步一个脚印。要不然从入门到放弃是大概率事件。 Python 官方文档教程
快到年末了 相信大家都在忙着处理年末数据 刚好有一个是对超市的商品库存进行分析的学员案例 真的非常简单~
一个简易的问答系统就这样完成了,当然,这个项目还可以进一步完善,比如 将数据存入Elasticsearch,通过它先进行初步的检索,然后再通过这个系统,当然我们也可以用其他的架构实现。如果你对这系统还有其他的疑问,也可以再下面进行留言!!!
#模版继承和页面之间的调用@app.route(&quot;/bl&quot;)def bl(): return render_template(&quot;file_2.html&quot;)主ht
#form表达提交@app.route(&quot;/data&quot;,methods=[&#39;GET&#39;,&#39;POST&#39;]) #methods 让当前路由支持GET 和
#form表达提交@app.route(&quot;/data&quot;,methods=[&#39;GET&#39;,&#39;POST&#39;]) #methods 让当前路由支持GET 和
#session 使用app.secret_key = &quot;dsada12212132dsad1232113&quot;app.config[&#39;PERMANENT_SESSION_LI
#文件上传@app.route(&quot;/file&quot;,methods=[&#39;GET&#39;,&#39;POST&#39;])def file(): if request.meth
#跳转操作:redirect@app.route(&quot;/red&quot;)def red(): return redirect(&quot;/login&quot;)
#session 使用app.secret_key = &quot;dsada12212132dsad1232113&quot;app.config[&#39;PERMANENT_SESSION_LI
@app.route(&quot;/req&quot;,methods=[&#39;GET&#39;,&#39;POST&#39;])def req(): print(request.headers)
#模版继承和页面之间的调用@app.route(&quot;/bl&quot;)def bl(): return render_template(&quot;file_2.html&quot;)主ht
#文件操作:send_file,支持图片 视频 mp3 文本等@app.route(&quot;/img&quot;)def img(): return send_file(&quot;1.jpg&q