zoukankan      html  css  js  c++  java
  • flask基础(上篇)


    目录

    一、flask入门与路由

    二、flask路由

    三、flask请求响应异常

    flask入门与路由

    1. flask介绍

    Flask是一个基于Python实现的web开发的'微'框架

    中文文档地址

    Flask和Django一样,也是一个基于MVC设计模式的Web框架

    flask流行的主要原因:

    a)有非常齐全的官方文档,上手非常方便
    
    b) 有非常好的拓展机制和第三方的拓展环境,工作中常见的软件都有对应的拓展,自己动手实现拓展也很容易
    
    c) 微型框架的形式给了开发者更大的选择空间
    

    2. 安装flask

    2.1虚拟环境搭建

    virtualenv --no-site-packages falskenv
    
    激活windows下虚拟环境
    cd Scripts
    activate
    

    2.2 安装

    pip install flask
    

    3. 基于flask的最小的应用

    创建hello.py文件

    from flask import Flask
    
    app = Flask(__name__)
    
    @app.route('/')
    def gello_world():
    	return 'Hello World'
    
    if __name__ == '__main__':
    
    	app.run()
    

    运行:python hello.py

    3.1 初始化

    from flask import Flask
    
    app = Flask(__name__)
    

    Flask类构造函数唯一需要的参数就是应用程序的主模块或包。对于大多数应用程序,Python的__name__变量就是那个正确的、你需要传递的值。Flask使用这个参数来确定应用程序的根目录,这样以后可以相对这个路径来找到资源文件。

    3.2 路由

    @app.route('/')
    

    客户端例如web浏览器发送 请求 给web服务,进而将它们发送给Flask应用程序实例。应用程序实例需要知道对于各个URL请求需要运行哪些代码,所以它给Python函数建立了一个URLs映射。这些在URL和函数之间建立联系的操作被称之为 路由 。

    在Flask应程序中定义路由的最便捷的方式是通过显示定义在应用程序实例之上的app.route装饰器,注册被装饰的函数来作为一个 路由

    3.3 视图函数

    在上一个示例给应用程序的根URL注册gello_world()函数作为事件的处理程序。如果这个应用程序被部署在服务器上并绑定了 www.example.com 域名,然后在你的浏览器地址栏中输入 http://www.example.com 将触发gello_world()来运行服务。客户端接收到的这个函数的返回值被称为 响应 。如果客户端是web浏览器,响应则是显示给用户的文档。

    类似于gello_world()的函数被称作 视图函数

    3.4 动态名称组件路由

    你的Facebook个人信息页的URL是 http://www.facebook.com/ ,所以你的用户名是它的一部分。Flask在路由装饰器中使用特殊的语法支持这些类型的URLs。下面的示例定义了一个拥有动态名称组件的路由:

    @app.route('/hello/<name>')
    
    def gello_world(name):
    
    	return 'Hello World %s' % name
    

    用尖括号括起来的部分是动态的部分,所以任何URLs匹配到静态部分都将映射到这个路由。当视图函数被调用,Flask发送动态组件作为一个参数。在前面的示例的视图函数中,这个参数是用于生成一个个性的问候作为响应。

    在路由中动态组件默认为字符串,但是可以定义为其他类型。例如,路由/user/int:id只匹配有一个整数在id动态段的URLs。Flask路由支持int、float

    如下:

    @app.route('/hello/<int:id>')
    
    def gello_stu_id(id):
    
      return 'Hello World id: %s' % id
    

    3.5 服务启动

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

    注意: __name__ == '__main__'在此处使用是用于确保web服务已经启动当脚本被立即执行。当脚本被另一个脚本导入,它被看做父脚本将启动不同的服务,所以app.run()调用会被跳过。

    一旦服务启动,它将进入循环等待请求并为之服务。这个循环持续到应用程序停止,例如通过按下Ctrl-C。

    有几个选项参数可以给app.run()配置web服务的操作模式。在开发期间,可以很方便的开启debug模式,将激活 debugger 和 reloader 。这样做是通过传递debug为True来实现的。

    run()中参数有如下:

    debug 是否开启调试模式,开启后修改python的代码会自动重启
    
    port 启动指定服务器的端口号
    
    host主机,默认是127.0.0.1
    

    4. 修改启动方式,使用命令行参数启动服务

    4.1 安装插件

    pip install flask-script
    

    调整代码
    manager = Manager(app=‘自定义的flask对象’)

    启动的地方
    manager.run()

    4.2 启动命令

    python hellow.py runserver -h 地址 -p 端口 -d -r
    

    其中:-h表示地址。-p表示端口。-d表示debug模式。-r表示自动重启

    5. route规则

    5.1 规则

    写法:converter:variable_name

    converter类型:

    string 字符串
    int 整形
    float 浮点型
    path 接受路径,接收的时候是str,/也当做字符串的一个字符
    uuid 只接受uuid字符串
    any 可以同时指定多种路径,进行限定
    

    例子:

    @app.route('/helloint/<int:id>/')
    
    @app.route('/getfloat/<float:price>/')
    
    @app.route('/getstr/<string:name>/',methods=['GET', 'POST'])
    
    @app.route('/getpath/<path:url_path>/')
    
    @app.route('/getbyuuid/<uuid:uu>/',methods=['GET', 'POST'])
    

    实现对应的视图函数:

    @blue.route('/hello/<name>/')
    def hello_man(name):
        print(type(name))
        return 'hello name:%s type:%s' % (name, type(name))
    
    @blue.route('/helloint/<int:id>/')
    def hello_int(id):
        print(id)
        print(type(id))
        return 'hello int: %s' % (id)
    
    @blue.route('/index/')
    def index():
        return render_template('hello.html')
    
    @blue.route('/getfloat/<float:price>/')
    def hello_float(price):
    
        return 'float: %s' % price
    
    @blue.route('/getstr/<string:name>/')
    def hello_name(name):
    
        return 'hello name: %s' % name
    
    @blue.route('/getpath/<path:url_path>/')
    def hello_path(url_path):
    
        return 'path: %s' % url_path
    
    @blue.route('/getuuid/')
    def gello_get_uuid():
        a = uuid.uuid4()
        return str(a)
    
    @blue.route('/getbyuuid/<uuid:uu>/')
    def hello_uuid(uu):
    
        return 'uu:%s' % uu
    

    5.2 methods请求方法

    常用的请求类型有如下几种

    GET : 获取
    POST : 创建
    PUT : 修改(全部属性都修改)
    DELETE : 删除
    PATCH : 修改(修改部分属性)
    

    定义url的请求类型:

    @blue.route('/getrequest/', methods=['GET', 'POST'])
    

    flask蓝图

    1. 什么是蓝图

    在Flask项目中可以用Blueprint(蓝图)实现模块化的应用,使用蓝图可以让应用层次更清晰,开发者更容易去维护和开发项目。蓝图将作用于相同的URL前缀的请求地址,将具有相同前缀的请求都放在一个模块中,这样查找问题,一看路由就很快的可以找到对应的视图,并解决问题了。

    2. 使用蓝图

    2.1 安装

    pip install flask_blueprint
    

    2.2 实例化蓝图应用

    blue = Blueprint(‘first’,\_\_name\_\_)
    

    注意:Blueprint中传入了两个参数,第一个是蓝图的名称,第二个是蓝图所在的包或模块,__name__代表当前模块名或者包名

    2.3 注册

    app = Flask(\_\_name\_\_)
    
    app.register_blueprint(blue, url_prefix='/user')
    

    注意:第一个参数即我们定义初始化定义的蓝图对象,第二个参数url_prefix表示该蓝图下,所有的url请求必须以/user开始。这样对一个模块的url可以很好的进行统一管理

    3 使用蓝图

    修改视图上的装饰器,修改为@blue.router(‘/’)

    @blue.route('/', methods=['GET', 'POST'])
    def hello():
        # 视图函数
        return 'Hello World'
    

    注意:该方法对应的url为127.0.0.1:5000/user/

    4 url_for反向解析

    后端中使用反向解析:

    语法:

    无参情况: url_for('蓝图中定义的第一个参数.函数名')
    有参情况: url_for('蓝图中定义的第一个参数.函数名', 参数名=value)
    

    定义跳转:

    from flask import url_for, redirect
    # 第一步: 生成蓝图对象
    blueprint = Blueprint('first', __name__)
    
    
    @blueprint.route('/')
    def hello():
        return 'hello'
    
    
    @blueprint.route('/stu/<id>/')
    def stu(id):
        return 'hello stu: %s' % id
    
    
    # 1. 定义路由跳转到hello方法
    @blueprint.route('/redirect/')
    def my_redirect():
    	# 第一种方法
        # redirect: 跳转
        # url_for: 反向解析
        # 'first.hello': 蓝图第一个参数.跳转到的函数名
        return redirect(url_for('first.hello'))
    	# 第二种方法
        return redirect('/hello/index/')
    	
    # 2. 定义路由跳转到stu方法
    @blueprint.route('/redirect_id/')
    def stu_redirect():
        return redirect(url_for('first.stu', id=3))
    

    注意: 反向解析可以使用url_for方法,也可以直接定义跳转的路由地址。

    前端中使用反向解析

    语法:

    无参形式: {{ url_for('蓝图中定义的第一个参数.函数名') }}
    
    有参形式: {{ url_for('蓝图中定义的第一个参数.函数名',参数名=value) }}
    

    flask请求响应异常

    1. 请求request

    服务端在接收到客户端的请求后,会自动创建Request对象

    由Flask框架创建,Requesy对象不可修改

    属性:

    url:完整的请求地址
    
    base_url:去掉GET参数的url
    
    host_url:只有主机和端口号的url
    
    path:路由中的路径
    
    method:请求方法
    
    remote_addr:请求的客户端的地址
    
    args:GET请求参数
    
    form:POST请求参数
    
    files:文件上传
    
    headers:请求头
    
    cookies:请求中的cookie
    

    1.1 args-->GET请求参数包装

    a)args是get请求参数的包装,args是一个ImmutableMultiDict对象,类字典结构对象

    b)数据存储也是key-value

    c) 获取GET请求中传递的参数,request.args

    1.2 form-->POST请求参数包装

    a)form是post请求参数的包装,args是一个ImmutableMultiDict对象,类字典结构对象

    b)数据存储也是key-value

    c) 获取POST请求中传递的参数,request.form

    重点:ImmutableMultiDict是类似字典的数据结构,但是与字典的区别是,可以存在相同的键

    在ImmutableMultiDict中获取数据的方式,dict['key']或者dict.get('key')或者dict.getlist('key')

    图片

    2. 响应Response

    Response是由开发者自己创建的

    创建方法:

    from flask import make_response
    
    make_response创建一个响应,是一个真正的Response对象
    

    状态码:

    格式:make_reponse(data,code),其中data是返回的数据内容,code是状态码

    a)直接将内容当做make_response的第一个参数,第二个参数直接写返回的状态码
    
    b)直接在render后加返回的状态码
    

    例子1:

    定义一个获取GET请求的request的方法,并将返回成功的请求的状态码修改为200

    @blue.route('/getrequest/', methods=['GET'])
    def get_request():
    
        print(request)
    
        return '获取request', 200
    

    例子2:

    返回response响应,并添加返回结果的状态码200

    @blue.route('/getresponse/')
    def get_response():
        response = make_response('<h2>我是响应</h2>', 500)
        return response
    

    或者:

    @blue.route('/getresponse/', methods=['GET'])
    def get_user_response():
        login_html = render_template('login.html')
        res = make_response(login_html, 200)
        return res
    

    3. 终止/异常捕获

    自动抛出异常:abort(状态码)

    捕获异常处理:errorhandler(状态码),定义的函数中要包含一个参数,用于接收异常信息

    3.1 定义终止程序

    @blue.route('/make_abort/')
    def get_abort():
        abort(400)
        return '终止'
    

    3.2 捕获定义的异常

    @blue.errorhandler(400)
    def handler(exception):
    
        return '捕获到异常信息:%s' % exception
  • 相关阅读:
    python_接口基础知识
    python_基础总结
    python_配置文件_yaml
    python_loggin日志处理
    python_数据驱动_ddt
    python_unittest_单元测试_openpyxl
    python_类与对象总结_继承
    python_路径操作及类和对象
    python_导包
    Codeforces Round #655 (Div. 2) B. Omkar and Last Class of Math
  • 原文地址:https://www.cnblogs.com/zhangliang91/p/11109128.html
Copyright © 2011-2022 走看看