Flask是使用python语言编写的一个轻量级的web框架
安装
pip install flask
它会默认安装几个基础的第三方模块
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服务器并启动服务
添加settings配置
if __name__ == "__main__":
# 运行程序[配置选项,推荐使用这样的方式,可以将配置单独部署在一个配置文件中,引入使用]
app.run(
debug=True,
host="0.0.0.0",
......
)
传递参数
- 路由传递参数和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
静态资源
- 创建templates文件和static文件
# 导入引入静态资源模块
from flask import render_template
def # 处理函数
# 从数据库中获取的数据
p = ......
# 返回首页网页视图,如果一旦使用render渲染网页
# flask会自动在当前文件所在的目录中查询模板文件夹templates
# 并在该文件夹下查询指定的网页index.html
return render_template("index.html", plist=persons)
文件上传
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))
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
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