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的主要内容,如果未能解决你的问题,请参考以下文章

flask基础1

python flask 基础入门

flask基础知识

[vscode]--HTML代码片段(基础版,reactvuejquery)

12_关于flask中的宏

flask基础之扩展