zoukankan      html  css  js  c++  java
  • 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()
    不将就
  • 相关阅读:
    JavaScript日期加减
    javascript乘除算法解决浮点精度
    npm的chalk包的使用
    npm模块copy-to-clipboard复制内容到剪切板
    BeeFramework 系列一 安装篇(Arc)
    CocoaPods详解之----使用篇
    ObjectiveC 深浅拷贝学习
    unity项目针对IOS及Android平台的音频压缩格式
    通过IP地址定位准确的地理位置
    Unity 通过代码简单实现文理的灰化显示
  • 原文地址:https://www.cnblogs.com/nq31/p/14311059.html
Copyright © 2011-2022 走看看