flask基础1
Posted pythonzrq
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了flask基础1相关的知识,希望对你有一定的参考价值。
Flask六行代码运行
# 六行启动Flask 提供HelloWorld from flask import Flask # 导入Flask 类创建Flask应用对象 app = Flask(__name__) # app = application @app.route("/index") # 为 Flask 应用对象增加路由 def index(): # 与路由绑定的视图函数 视图函数名尽可能保持唯一 return "HelloWorld" # “” 相当于 Django 中的 HttpResponse if __name__ == ‘__main__‘: # 当前文件处于脚本状态时运行如下代码 app.run() # 启动Flask 应用
Flask 中的 Response
常用返回值
1.HTTPResponse("HelloWorld") "HelloWorld" 2.render("html文件") render_template("HTML文件") # 默认存放路径是"templates" # 文件html黄色 解决步骤 右键templats->Mark Directory as->Templates Folder Template Languages更改默认语言为jinjia2 3.redirect("/home") redirect("/home") # ResponseHeaders 中加入了一个 Localtion:http://url 为重定向位置
特殊返回值
# Flask 特殊返回值 4.send_file("文件路径") 返回文件 # 打开并返回文件内容 自动识别文件类型 在ResponseHeaders中加入 # Content-Type:文件类型 - *文件类型 是可以被客户端识别的文件类型 # 不能识别的类型 下载处理 - 浏览器会下载 ###### x-ms x二进制 ms微软 wma文件 5.jsonify("字符串或数据类型") 返回标准格式的JSON字符串 # Content-Type:application/json == 标准格式 # Flask 1.1.1 # return d # 暂时不建议使用 兼容性 # 直接返回dict时 本质上在执行jsonify(d) # API 接口 AJAX.post({username:123}){ function(data){ obj = data }} # 1.打包JSON 序列化JSON字符串 # 2.编写ResponseHeaders 加入 Content-Type:application/json # 利用 Flask 做一个登录 username password # request?
Flask 中的 Request
methods=["GET","POST"] 在添加路由的装饰器中允许请求方式,覆盖 1.request.form 获取FormData中的数据 to_dict() ImmutableMultiDict 2.request.method 获取请求方式 3.request.args # 获取URL中的数据 字符串 get("key") to_dict() GET # 在Django request.GET 取出 URL 中的参数 # 在Flask 获取URL 中的参数 # print(request.url) # 请求地址 # print(request.url_charset) # URL 编码方式 # print(request.url_root) # 请求地址 完整请求地址 host # print(request.url_rule) # 请求路由地址 # print(request.values.to_dict()) # 接收所有(GET,POST)请求中的数据,包含了 URL 和 FormData 中的数据 # print(request.args.get("id")) # 获取URL中的数据 字符串 POST # 在Django request.POST 取出 FormData (Form表单) # 在Flask 获取FormData request.form # print(request.form.get("username")) # print(request.form.to_dict()) 获取一个 FileStorage Flask文件特殊对象 # print(request.files.get("my_file")) "获取文件名my_file的文件" # my_file = request.files.get("my_file") # new_file = os.path.join("xht",my_file.filename) "xht文件下,拼接原文件名" # my_file.save(new_file) "保存文件,重命名" 获取其他数据 # request.headers # request.cookies # request.path == request.url_rule # request.host == "127.0.0.1:9527" # request.host_url == "http://127.0.0.1:9527/" 特殊提交方式数据获取 # Content-Type:application/json # request.json 获取Content-Type:application/json时提交的数据 # Content-Type 无法被识别 或 不包含Form字眼 # request.data 获取 原始请求体中的数据 b""
Flask中的Session
from flask import session app = Flask(__name__) # __name__ app.secret_key = "!@#$%^&*()" # 开启秘钥 sesion正常流程
session 服务器端的键值对
cookie 客户端的键值对
交由客户端保管机制
1.开启session[username] = 123
{
username=123
}
2.序列化字典 == 字符串
3.加密字符串 SecreKey 秘钥字符串
接收反序列化Session
1.从Cookie中获取到一个叫 Session key 的值
2.通过SecreKey的值
3.反序列化成字典
Flask开启Debug
app.debug=True
Jinja2
{{}} #引用变量数据 执行函数 {%%} # 逻辑代码
以上是关于flask基础1的主要内容,如果未能解决你的问题,请参考以下文章