首页 > 其他分享 >Flask - 基础知识入门解析

Flask - 基础知识入门解析

时间:2023-05-05 17:35:16浏览次数:35  
标签:入门 form Flask request 基础知识 url file print

Flask - 基础知识入门解析

框架比较

Django web框架:
优点 - 组件非常全,教科书框架,admin model-ORM session
缺点 - 资源浪费,因为组件多,大,还是互相关联的,随便卸载组件,可能会造成项目的崩溃
 
Flask web框架:
优点 - 扩展性强,精简,简单,第三方组件丰富 session Flask-Session Flask-Admin
缺点 - 稳定性相对较差 ,第三方组件新版兼容性
缺点 - 复杂度较高

一. Flask 的安装 和 程序员仪式

安装

pip install Flask
也可以在Pycharm中选择安装~

程序员仪式

启动app.py下

from flask import Flask       # 带入Flask类
app = Flask(__name__)         # 实例化Flask对象 app

@app.route('/')               # app中的路由装饰器
def hello_world():            # 视图函数
        return 'Hello World!'

if __name__ == '__main__':
    app.run(debug=True)       # 启动服务

浏览器访问127.0.0.1:5000, 就会完成Flask的程序员仪式, 欢迎你成为一个Flask用户!!!

相关的包的引用:

  • jinja 模板渲染工具

  • MarkUpSafe 安全标签 Flask返回模板标签时,都会依赖MarkUpSafe

  • Werkzeug (德文) 工具 相当于django 的 uWSGI 底层是WSGI

二. Flask 的返回值Response

1.return HttpResponse("疯哥真帅!")

# 跟django中一样, 直接返回字符串

2.return render_template("login.html")返回模板页面

# 返回一个html模板,类似django中 render
@app.route('/login')
def login():
      return render_template('login.html')

3.return redirect("/")重定向

# 与django中相同, 重定向,访问"/re"跳转到"/home"
@app.route("/re")
def re():
    return redirect("/home")

4.return send_file("file.mp4") 返回文件

# 打开并返回文件内容 自动识别文件类型并且在响应头中自动加入 Content-type:文件类型 
     不能识别的类型浏览器会执行下载操作
@app.route("/get_file")
def get_file():
    return send_file("1.jpg")

5.return jsonify({"key": "value"}) 返回JSON数据

# 返回标准格式的jsonz字符串, 在响应头中加入Content-type:application
@app.route("/get_json")
def get_json():
    d = {
        "name": "Alexander.DSB.Li"
    }
    return jsonify(d)  # Content-Type:application/json
    # Flask 1.1.1
    # return d  # 暂时不建议使用 兼容性
    # 直接返回dict时 本质上在执行jsonify(d)

三. Flask 请求request

请求案例如下

from flask import Flask, render_template, request, redirect,session

app = Flask(__name__)  # __name__
app.secret_key = "!@#$%^&*()"
app.debug = True  # 开启Debug模式

@app.route("/login", methods=["GET", "POST"])  # 405 请求方式不被允许
def login():
    # 从request中取出请求方式
    # 判断请求方式 GET render POST 处理
    if request.method == "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中的数据 字符串
        return render_template("login.html")
    if request.method == "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 = request.files.get("my_file")
        # new_file = os.path.join("xht",my_file.filename)
        # 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""

        if request.form.get("username") == "Alexander.DSB.Li":
            session["user"] = request.form.get("username")
            return redirect("/")


@app.route("/")
def index():
    print(session.get("user"))
    return render_template("index.html")


if __name__ == '__main__':
    app.run("0.0.0.0", 9527)
# 监听地址 和 端口

1.request.method

# 返回请求的方式, post,get...

2.request.form

	# 返回Form表单中传递传过来的值
    print(request.form)  # ImmutableMultiDict([('user', 'kong'), ('pwd', 'hui')])

    # ImmutableMultiDict 它看起来像是的Dict 就用Dict的方法取值试一下吧
    print(request.form["user"])  # kong
    print(request.form.get("pwd"))  # hui

    # 看来全部才对了, ImmutableMultiDict 似乎就是个字典,再来玩一玩它
    print(list(request.form.keys()))  # ['user', 'pwd'] 看来是又才对了

    #如果以上所有的方法你都觉得用的不爽的话
    req_dict = dict(request.form)
    print(req_dict)  # 如果你觉得用字典更爽的话,也可以转成字典操作(这里有坑)

3.request.args

# 返回url中传递的参数

image-20230409075637776

然后我们看下:

url=http://127.0.0.1:5000/req?id=1&age=20

return OK OldBoy

print(request.args)  # ImmutableMultiDict([('id', '1'), ('age', '20')])

print(request.args["id"])  # 1

print(request.args.get("age"))  # 20

print(list(request.args.keys()))  # ['id', 'age']

print(list(request.args.values()))  # ['1', '20']

req_dict = dict(request.args)  # {'id': ['1'], 'age': ['20']}

与 request.form的区别:

  • request.args 是获取url中的参数
  • request.form 是获取form表单中的参数

4.request.values

前端代码:

<body>
Welcome to Old Boy EDU
<form action="/req?id=1&age=20" method="post">
    用户名:<input type="text" name="user">
    密码:<input type="text" name="pwd">
    <input type="submit" value="提交">
</form>
</body>

看返回结果:

print(request.values)  # CombinedMultiDict([ImmutableMultiDict([('id', '1'), ('age', '20')]), ImmutableMultiDict([('user', 'Oldboy'), ('pwd', 'DragonFire')])])

print(request.values.get("id"))  # 1

print(request.values["user"])  # Oldboy

# 这回喜欢直接操作字典的小伙伴们有惊喜了! to_dict() 方法可以直接将我们的参数全部转为字典形式
print(request.values.to_dict()) # {'user': 'Oldboy', 'pwd': 'DragonFire', 'id': '1', 'age': '20'}

但是有坑!!

    # 如果url和form中的Key重名的话,form中的同名的key中value会被url中的value覆盖
    # http://127.0.0.1:5000/req?id=1&user=20
    print(request.values.to_dict())  # {'user': 20 'pwd': 'DragonFire', 'id': '1'}

5.request.cookies

# 返回浏览器中的cookies信息

6.request.headres

# 返回请求头中数据
print(type(request.headers))
"""
Host: 127.0.0.1:5000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Referer: http://127.0.0.1:5000/home
Content-Type: application/x-www-form-urlencoded
Content-Length: 26
Cookie: csrftoken=vDIozqveCEfArdYXlM6goHVlSQEn7h4bDygNphL2Feas60DiM2di0jlqKfxo7xhA
Connection: keep-alive
Upgrade-Insecure-Requests: 1
Cache-Control: max-age=0
"""

7.request.data

# b"" 
	存放的是请求体中的原始信息 Content-Type:asdfkjashgjvajhgjkow

8.request.json

# 请求头中存在 Content-Type:application/json 将请求体中的数据 存放在JSON中,没有返回None

9.request.files

如果遇到文件上传的话,request.files 里面存的是你上传的文件,但是 Flask 在这个文件的操作中加了一定的封装,让操作变得极为简单.

Welcome to Old Boy EDU
<form action="/req" enctype="multipart/form-data">
    <input type="file" name="file">
    <input type="submit" value="提交">
</form>

后端代码:

	print(request.files)  # ImmutableMultiDict([('file', <FileStorage: 'DragonFire.txt' ('text/plain')>)])
    print(request.files["file"])  # <FileStorage: 'DragonFire.txt' ('text/plain')>
    my_file = request.files["file"]
    my_file.save("OldBoyEDU.txt")  # 保存文件,里面可以写完整路径+文件名

10.request获取路径

# 获取当前的url路径
print(request.path)# /req

# 当前url路径的上一级路径
print(request.script_root) #

# 当前url的全部路径
print(request.url) # http://127.0.0.1:5000/req

# 当前url的路径的上一级全部路径
print(request.url_root ) # http://127.0.0.1:5000/

标签:入门,form,Flask,request,基础知识,url,file,print
From: https://www.cnblogs.com/mengdie1978/p/17374820.html

相关文章

  • flask blueprint
    定义fromflaskimportBlueprintfrom.importdataApidefregister_url():bp=Blueprint('layers',__name__,url_prefix='/<regex("[0-9a-zA-Z-]+"):system>/<SN>/<source>/<project_id>')bp.add_u......
  • 52班JAVA入门基础课堂代码
    Demo01_数组的概念和定义格式packageday01;publicclassDemo01_数组的概念和定义格式{publicstaticvoidmain(String[]args){//intage=19;//容器大小,同类型的元素,长度----元素的个数////数组---容器的一种,长度固定,......
  • flask 服务器简单搭建
    一个简单的服务器过程大概分为4步1、搭建服务2、监听动作,while,0.1s监听3、处理程序4、返回数据到套接字,生成一个响应对象 搭建简单的服务器  前端访问 ......
  • Go语言入门14(channel通道01)
    channel(一)​ channel用于goroutines之间的通信,让它们之间可以进行数据交换。像管道一样,一个goroutine_A向channel_A中放数据,另一个goroutine_B从channel_A取数据channel基本语法//因为channel是指针类型的数据类型,所以通过make来分配内存//使用make声明一个channel,里面可以......
  • 人工智能学习入门学习笔记 1
    目前人工智能算法分哪几类,哪些是需要训练的?人工智能算法通常可以分为以下几类:1. 监督学习(SupervisedLearning):需要有标注数据,即输入数据与输出结果是已知的,算法通过学习这些数据来建立一个输入到输出的映射模型。例如,图像分类、自然语言处理和预测等任务。2. 无监督学习(Unsupervi......
  • 《CTFshow-Web入门》08. Web 71~80
    目录web71知识点题解web72知识点题解web73题解web74题解web75知识点题解web76题解web77知识点题解web78知识点题解web79题解web80知识点题解ctf-web入门web71知识点ob_get_contents():得到输出缓冲区的内容。ob_end_clean():清除缓冲区的内容,并将缓冲区关闭,但不会输出内......
  • FirewallD入门手册
    导读FirewallD是iptables的一个封装,可以让你更容易地管理iptables规则-它并不是iptables的替代品。虽然iptables 命令仍可用于FirewallD,但建议使用FirewallD时仅使用FirewallD 命令。 FirewallD是iptables的前端控制器,用于实现持久的网络流量规则。......
  • C语言从入门到精通
    1.C语言较为底层,更接近硬件,效率较高,因此更合适用于开发操作系统;2.C语言支持函数操作,但它并不属于函数式编程。函数式编程可以理解为高级的函数操作,例如,函数的嵌套定义、匿名函数、闭包、惰性求值等等,但C语言中,基本上只能常规的定义函数、调用函数;常量、变量和关键字数据类......
  • 图像识别入门教程,带你从零到一!
    图像识别是一门利用计算机技术来识别和处理图像中的信息的学科。图像识别的应用非常广泛,例如人脸识别、车牌识别、医学影像分析等。本教程将带你从零到一,了解图像识别的基本原理和方法,以及如何使用Python和TensorFlow等工具来实现图像识别的任务。本教程分为以下几个部分:-第一部......
  • [Python]-sklearn模块-机器学习Python入门《Python机器学习手册》-05-处理分类数据
    《Python机器学习手册——从数据预处理到深度学习》这本书类似于工具书或者字典,对于python具体代码的调用和使用场景写的很清楚,感觉虽然是工具书,但是对照着做一遍应该可以对机器学习中python常用的这些库有更深入的理解,在应用中也能更为熟练。以下是根据书上的代码进行实操,注释......