Flask 快速入门

作者: 依旧丶森 | 来源:发表于2018-01-03 20:45 被阅读7次

Flask是使用python语言编写的一个轻量级的web框架。

1. 安装

pip install flask
它会默认安装几个基础的第三方模块。

翻译中文官方文档(http://python.usyiyi.cn/translate/flask_011_ch/index.html)

2. Hello,World!

      # 引入需要的模块   flask核心处理模块
      from flask import Flask
      # 通过当前文件构建一个app应用~~当前文件就是 web app程序的入口
      app = Flask(__name__)

      # 定义视图处理函数~路由+视图函数(绑定在一起)->加载到 app 中
      @app.route(“/”)
      def hello():
            return “Hello Flask!”
      #启动程序
      if __name__ == “__main__”:
              app.run()

flask.Flask
核心模块之一,Flask可以构建封装完成的WSGI应用
flask.Flask.route(path)
核心模块之一,Flask应用中的路由配置,主要加载在视图操作函数上,完成path路径和视图函数之间的路由映射关系
flask.Flask.run()
核心模块之一的函数,通过run()函数将web应用部署到web服务器并启动服务

3.添加 setting 配置

    if __name__ == "__main__":
    # 运行程序[配置选项,推荐使用这样的方式,可以将配置单独部署在一个配置文件中,引入使用]
    app.run(
         debug=True,
          host="0.0.0.0",
          ......
    )

4. 传递参数

  • 路由传递参数,和tornado类似

        @app.route("/index/<username>")
        def index(username):
            return "<h1>hello %s!</h1>" % username
    
    
  • GET/POST传递参数,通过methods=['GET/POST']确定文件传递接收

        #接收参数的模块
        from flask import request
    
        @app.route("/get")
        def get_method():
             # request请求对象,请求对象中的args属性用于专门接受get参数
             get_name = request.args.get("get_name")
             return "<h1>receive get: %s</h1>" % get_name
    
        @app.route("/post", methods=["POST"])
        def post_method():
             # request请求对象中的属性form 表单对象,专门用于接受post参数
             post_name = request.form.get("post_name")
             return "<h1>receive post: %s</h1>" % post_name
    

5.静态资源

创建 templates 文件 和 static 文件

    #导入引入静态资源模块
    from flask import  render_template
    def #处理函数
          # 从数据库中获取的数据
          p = ......
          # 返回首页网页视图,如果一旦使用render渲染网页
          # flask会自动在当前文件所在的目录中查询模板文件夹templates
          # 并在该文件夹下查询指定的网页index.html
          return render_template("index.html", plist=persons)
    #静态资源直接网页引入。

6. 文件上传

     import os
     from flask import Flask, request, redirect, url_for, flash
     from werkzeug.utils import secure_filename

     # 文件上传路径
     UPLOAD_FOLDER = '/path/to/the/uploads'
     # 允许上传文件的文件名称:任何时候,不要让用户选择上传的文件[用户是千变万化的!]
     ALLOWED_EXTENSIONS = set(['txt', 'pdf', 'png', 'jpg', 'jpeg', 'gif'])

     app = Flask(__name__)
     # 将上传路径配置给web应用程序
     app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
     #上传文件限制为最大 16 MB 。 如果传输较大的文件将产生[`RequestEntityTooLarge`]异常。
     #app.config['MAX_CONTENT_LENGTH'] = 16 * 1024 * 1024

     # 定义一个函数,用于判断文件的后缀名称
     def allowed_file(filename):
           #  "." in filename  判断是不是有 ' . '  >> True / False
           # "filename".rsplit('.', 1)[1].lower in ALLOWED_EXTENSIONS >> True/Flase
           #判断文件后缀是不是符合允许上传的文件后缀
           return '.' in filename and \
           filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS


      # 上传文件的核心操作代码,允许通过get/post两种方式访问这个视图函数
      @app.route('/', methods=['GET', 'POST'])
      def upload_file():
             #如果用户通过post请求,应该是要上传文件了
             if request.method == 'POST':
                    #判断用户提交的表单数据库中是否包含了 文件
                    if 'file' not in request.files:
                            #在响应中给用户返回一个消息
                            flash('用户没有提交文件')
                            #如果没有包含文件,直接重定向跳转到用户访问的路径中
                            return redirect(request.url)

                    #获取用户表单中提交的文件,根据name属性直接获取
                    file = request.files['file']
                    #判断文件名称是否存在,如果不存在提示用户没有选择文件
                    if file.filename == '':
                            flash('用户没有选择任何文件')
                            return redirect(request.url)

                     # 判断用户已经上传了文件,判断~文件的后缀名称是否满足需要
                    if file and allowed_file(file.filename):
                            # 判断并获取文件的名称,避免出现文件注入覆盖问题
                            filename = secure_filename(file.filename)
                            # 保存文件
                            file.save(os.path.join(app.config['UPLOAD_FOLDER'], filename))
                            # 请求重定向跳转到指定的视图函数
                            return redirect(url_for('uploaded_file',
                                    filename=filename))
  
      if __name__ == "__main__":
            s = "headeimg.mp4"
            print(allowed_file(s))

文件上传:web项目中非常重要的常见的一个功能
在文件上传操作过程中,会存在一定的安全问题,业务功能涉及到用户将文件提交到服务器进行保存,所以要注意用户有可能提交非法文件到服务器中的某个路径,覆盖服务器上的文件,达到远程代码通过上传的文件注入到服务器进行提权的漏洞!某些非法访问人员就有可能获取到服务器的最高权限!

7.Cookie

文档(http://dormousehole.readthedocs.io/en/latest/quickstart.html?highlight=cookie)

  • 向cookie中存储数据
        from flask import make_response
        @app.route('/')
        def index():
            resp = make_response(render_template(...))
            resp.set_cookie('username', 'the username')
            return resp
    
  • 从cookie中获取数据
        from flask import request
        username = request.cookies.get('username')
        # 使用 cookies.get(key) 来代替 cookies[key] ,
        # 以避免当 cookie 不存在时引发 KeyError 。
    
  • 删除cookie
          (1) 可以通过在浏览器中设置来清除cookie.
          (2) 使用Response的set_cookie进行清除,直接设置为空
          response.set_cookie('Name','',expires=0)  
          return response  
          (3)使用Response的 delete_cookie方法.
          @app.route('/del_cookie2')  
          def del_cookie2():  
               response=make_response('delete cookie2')  
               response.delete_cookie('Name')  
               return response
    

8.Session

使用session时,首先添加一个安全混淆秘钥app.secret_key = “Iw1SapGPQSibYrOQrHtLUQ==“

  • 向session中存储数据

        from flask import session
        app = Flask(__name__)
    
        @app.route(“/session/<name>“)
        def session_set(name):
               session[“name”] = name
               return “session operations ok!”
    
    
  • 从session中获取数据

        @app.route(“/session_get”)
        def session_get():
             value = session.get(“name”)
             return “session operations: %s” % value
    

9. 项目部署

参考官方文档(http://docs.jinkan.org/docs/flask/deploying/index.html#deployment)

相关文章

网友评论

    本文标题:Flask 快速入门

    本文链接:https://www.haomeiwen.com/subject/rjsknxtx.html