zoukankan      html  css  js  c++  java
  • 快速入门

    Flask简介

    Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后触发Flask框架,开发人员基于Flask框架提供的功能对请求进行相应的处理,并返回给用户,如果要返回给用户复杂的内容时,需要借助jinja2模板来实现对模板的处理,即:将模板和数据进行渲染,将渲染后的字符串返回给用户浏览器。

    “微”(micro) 并不表示你需要把整个 Web 应用塞进单个 Python 文件(虽然确实可以 ),也不意味着 Flask 在功能上有所欠缺。微框架中的“微”意味着 Flask 旨在保持核心简单而易于扩展。Flask 不会替你做出太多决策——比如使用何种数据库。而那些 Flask 所选择的——比如使用何种模板引擎——则很容易替换。除此之外的一切都由可由你掌握。如此,Flask 可以与您珠联璧合。

    默认情况下,Flask 不包含数据库抽象层、表单验证,或是其它任何已有多种库可以胜任的功能。然而,Flask 支持用扩展来给应用添加这些功能,如同是 Flask 本身实现的一样。众多的扩展提供了数据库集成、表单验证、上传处理、各种各样的开放认证技术等功能。Flask 也许是“微小”的,但它已准备好在需求繁杂的生产环境中投入使用。

    安装

    pip3 install flask
    

    werkzeug简介

    Werkzeug是一个WSGI工具包,他可以作为一个Web框架的底层库。这里稍微说一下, werkzeug 不是一个web服务器,也不是一个web框架,而是一个工具包,官方的介绍说是一个 WSGI 工具包,它可以作为一个 Web 框架的底层库,因为它封装好了很多 Web 框架的东西,例如 Request,Response 等等。
    代码示例:

    from werkzeug.wrappers import Request, Response
    
    
    @Request.application
    def hello(request):
        return Response('hello world')
    
    
    if __name__ == '__main__':
        from werkzeug.serving import run_simple
    
        run_simple('localhost', 4000, hello)
    

    flask快速使用

    from flask import Flask
    
    # 实例化产生一个Flask对象
    app = Flask(__name__)
    
    
    # 将'/'和视图函数hello_world的对应关系添加到路由中
    @app.route('/')  # 1.v=app.route('/')  2.v(hello_world)
    def hello_world():
        return 'hello world'
    
    
    if __name__ == '__main__':
        app.run()  # 最终调用了run_simple
    '''
    在run()最后
    
    from werkzeug.serving import run_simple
    
    try:
        run_simple(host, port, self, **options)
    finally:
        # reset the first request information if the development server
        # reset normally.  This makes it possible to restart the server
        # without reloader and that stuff from an interactive shell.
        self._got_first_request = False
    '''
    # 所以说Flask框架是基于werkzeug工具包的
    
    

    案例:登录,显示用户信息

    from flask import Flask, render_template, request, redirect, session
    
    app = Flask(__name__)
    app.secret_key = '123456'
    USERS = {
        1: {'name': '张三', 'age': 18, 'gender': '男', 'text': "道路千万条"},
        2: {'name': '李四', 'age': 28, 'gender': '男', 'text': "安全第一条"},
        3: {'name': '王五', 'age': 18, 'gender': '女', 'text': "行车不规范"},
    }
    
    
    @app.route('/login/', methods=['GET', 'POST'])
    def login():
        if request.method == "GET":
            return render_template('login.html')
        else:
            username = request.form.get('username')
            password = request.form.get('password')
            if username == 'sjh' and password == '1234':
                session['user_info'] = username
                return redirect('/')
            return render_template('login.html', error='用户名或密码错误')
    
    
    @app.route('/')
    def index():
        user = session.get('user_info')
        if not user:
            return redirect('/login')
        return render_template('index.html', users=USERS)
    
    
    @app.route('/detail/<int:id>',methods=['GET'])
    def detail(id):
        user = session.get('user_info')
        if not user:
            return redirect('/login')
        info = USERS.get(id)
        return render_template('detail.html', info=info)
    
    
    if __name__ == '__main__':
        app.run()
    
    
    //index.html
    <h1>用户列表</h1>
    <table>
        {% for k,v in users.items() %}
        <tr>
            <td>{{ k }}</td>
            <td>{{ v.name }}</td>
            <td>{{ v['name'] }}</td>
            <td>{{ v.get('name') }}</td>
            <td><a href="/detail/{{k}}">查看详情</a></td>
        </tr>
        {% endfor %}
    </table>
    
    //login.html
    <h1>登录页面</h1>
    <form method="post">
        <input type="text" name="username">
        <input type="password" name="password">
        <input type="submit" value="登录">{{ error }}
    </form>
    
    detail.html
    <h1>{{ info['name'] }}</h1>
    <div>
        {{ info.age }}
        {{ info.gender }}
        {{ info.text }}
    </div>
    

    登录认证装饰器

    多个装饰器执行顺行
    最左边最后执行
    反向查找的名称(endpoint),不允许重复

    配置文件

    flask中的配置文件是一个flask.config.Config对象(继承字典),默认配置为:

     {
            'DEBUG':                                get_debug_flag(default=False),  是否开启Debug模式
            'TESTING':                              False,                          是否开启测试模式
            'PROPAGATE_EXCEPTIONS':                 None,                          
            'PRESERVE_CONTEXT_ON_EXCEPTION':        None,
            'SECRET_KEY':                           None,
            'PERMANENT_SESSION_LIFETIME':           timedelta(days=31),
            'USE_X_SENDFILE':                       False,
            'LOGGER_NAME':                          None,
            'LOGGER_HANDLER_POLICY':               'always',
            'SERVER_NAME':                          None,
            'APPLICATION_ROOT':                     None,
            'SESSION_COOKIE_NAME':                  'session',
            'SESSION_COOKIE_DOMAIN':                None,
            'SESSION_COOKIE_PATH':                  None,
            'SESSION_COOKIE_HTTPONLY':              True,
            'SESSION_COOKIE_SECURE':                False,
            'SESSION_REFRESH_EACH_REQUEST':         True,
            'MAX_CONTENT_LENGTH':                   None,
            'SEND_FILE_MAX_AGE_DEFAULT':            timedelta(hours=12),
            'TRAP_BAD_REQUEST_ERRORS':              False,
            'TRAP_HTTP_EXCEPTIONS':                 False,
            'EXPLAIN_TEMPLATE_LOADING':             False,
            'PREFERRED_URL_SCHEME':                 'http',
            'JSON_AS_ASCII':                        True,
            'JSON_SORT_KEYS':                       True,
            'JSONIFY_PRETTYPRINT_REGULAR':          True,
            'JSONIFY_MIMETYPE':                     'application/json',
            'TEMPLATES_AUTO_RELOAD':                None,
        }
    
    方式一
    app.config['DEBUG'] = True
    PS:由于Config对象本质上是字典,所以还可以使用app。config.update(...)
    
    方式二
    # 通过py文件配置
    app.config.from_pyfile("python文件名称")
    如:
    settings.py
    DEBUG = True
    
    app.config.from_pyfile("settings.py")
    #通过环境变量配置
    app.config.from_envvar("环境变量名称")
    #app.config.from_pyfile(os.environ['YOURAPPLICATION_SETTINGS'])
    # 环境变量的值为python文件名称,内部调用from_pyfile方法
    
    app.config.from_json("json文件名称")
    JSON文件名称,必须是json格式,因为内部会执行json.loads
    
    app.config.from_mapping({"DEBUG": True})
    # 字典格式
    
    app.config.from_object("python类或类的路径")
    app.config.from_object('pro_flask.settings.TestingConfig')
    
    #settings.py
    class Config(object):
        DEBUG = False
        TESTING = False
        DATABASE_URI = 'sqlite://:memory:'
    
    
    class ProductionConfig(Config):
        DATABASE_URI = 'mysql://user@localhost/foo'
    
    
    class DevelopmentConfig(Config):
        DEBUG = True
    
    
    class TestingConfig(Config):
        TESTING = True
        
        
    PS:从sys.path中已经存在路径开始写
    PS: settings.py文件默认路径要放在程序root_path目录,如果instance_relative_config为True,则就是instance_path目录(Flask对象init方法的参数)
    
  • 相关阅读:
    java线程简要
    Unable to find explicit activity class
    用NetBeans生成jar文件
    Linux下三个可以修改环境变量的地方
    linux定时执行shell脚本
    sql server 性能调优之 SQL语句阻塞查询
    sql server 性能调优之 死锁排查
    IObit Advanced SystemCare 系统清理优化工具
    IDEA配置Maven
    maven的生命周期及常用命令的使用
  • 原文地址:https://www.cnblogs.com/ShenJunHui6/p/11219465.html
Copyright © 2011-2022 走看看