Python学习之旅

Flask 快速入门

2018-01-03  本文已影响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. 传递参数

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)

8.Session

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

9. 项目部署

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

上一篇下一篇

猜你喜欢

热点阅读