fastapi 传输文件存文件_FastAPI框架入门 基本使用, 模版渲染, form表单数据交互, 上传文件, 静态文件配置...

本文介绍了FastAPI框架的基本使用,包括GET和POST请求、模板渲染、表单数据交互、文件上传以及静态文件配置。通过实例展示了如何接收GET请求、处理POST请求中的表单数据、上传单个和多个文件,并将文件保存到本地。同时也提到了FastAPI的模板渲染功能,使用Jinja2模板库。
摘要由CSDN通过智能技术生成

安装

pip install fastapi[all]

pip install unicorn

基本使用(不能同时支持,get, post方法等要分开写)

from fastapi import FastAPI

app = FastAPI()

@app.get('/') # 点get就支持get请求

def read_root():

return {"hello":'world'}

if __name__ == '__main__':

import uvicorn

uvicorn.run(app,host='127.0.0.1',port=8080)

模版渲染

fastapi本身是没有模版渲染功能的,需要你借助于第三方的模版工具

该框架默认情况下也是借助于jinja2来做模版渲染(flask也是使用jinja2, 如果用过flask, 默认是装过jinja2)

# 安装

pip install jinja2

# 基本使用

from starlette.requests import Request

from fastapi import FastAPI

from starlette.templating import Jinja2Templates

app = FastAPI()

# 挂载模版文件夹

tmp = Jinja2Templates(directory='templates')

@app.get('/')

async def get_tmp(request:Request): # async加了就支持异步 把Request赋值给request

return tmp.TemplateResponse('index.html',

{'request':request, # 一定要返回request

'args':'hello world' # 额外的参数可有可无

}

)

@app.get('/{item_id}/') # url后缀

async def get_item(request:Request,item_id):

return tmp.TemplateResponse('index.html',

{'request':request,

'kw':item_id

})

if __name__ == '__main__':

import uvicorn

uvicorn.run(app,host='127.0.0.1',port=8080)

# index.html文件内容

{# index.html #}

index页面

{{ args }}

{{ kw }}

form表单数据交互

注意: 如果要使用request.form()支持表单“解析”,则为必需 python-multipart 。

# 安装

pip install python-multipart

from starlette.requests import Request

from fastapi import FastAPI,Form

from starlette.templating import Jinja2Templates

app = FastAPI()

tmp = Jinja2Templates(directory='templates')

@app.get('/') # 接受get请求

async def get_user(request:Request):

return tmp.TemplateResponse('form.html',{'request':request})

@app.post('/user/') # 接受post请求

async def get_user(request:Request,

username:str=Form(...), # 直接去请求体里面获取username键对应的值并自动转化成字符串类型

pwd:int=Form(...) # 直接去请求体里面获取pwd键对应的值并自动转化成整型

):

print(username,type(username))

print(pwd,type(pwd))

return tmp.TemplateResponse('form.html',{

'request':request,

'username':username,

'pwd':pwd

})

if __name__ == '__main__':

import uvicorn

uvicorn.run(app,host='127.0.0.1',port=8080)

# form.html文件内容

{# form.html #}

username

password

{{ username }}

{{ pwd }}

上传文件

from starlette.requests import Request

from fastapi import FastAPI, Form, File, UploadFile

from starlette.templating import Jinja2Templates

from typing import List

app = FastAPI()

# 挂载模板文件夹

tmp = Jinja2Templates(directory='templates')

@app.get('/') # 接受get请求

async def get_file(request: Request):

return tmp.TemplateResponse('file.html', {'request': request})

# 单个文件

@app.post('/file/') # 接受post请求

async def get_user(request: Request,

file: bytes = File(...), # # 把文件对象转为bytes类型,这种类型的文件无法保存

file_obj: UploadFile = File(...), # UploadFile转为文件对象,可以保存文件到本地

info: str = Form(...) # 获取普通键值对

):

# 保存上传的文件

contents = await file_obj.read()

with open("static/file/" + file_obj.filename, "wb") as f:

f.write(contents)

return tmp.TemplateResponse('index.html', {

'request': request,

'file_size': len(file),

'file_name': file_obj.filename,

'info':info,

'file_content_type':file_obj.content_type

})

# 多个文件

@app.post('/files/')

async def get_files(request:Request,

files_list:List[bytes] = File(...), # [文件1的二进制数据,文件2的二进制数据]

files_obj_list:List[UploadFile]=File(...) # [file_obj1,file_obj2,....] # 文件框里可以同时上传多个文件

):

# 保存上传的多个文件

for file in files_obj_list:

contents = await file.read()

filename = file.filename

with open("static/file/" + filename, "wb") as f:

f.write(contents)

return tmp.TemplateResponse('index.html',

{'request':request,

'file_sizes':[len(file) for file in files_list],

'file_names':[file_obj.filename for file_obj in files_obj_list]

}

)

if __name__ == '__main__':

import uvicorn

uvicorn.run(app, host='127.0.0.1', port=8080)

# html页面文件内容,有俩html文件

{# file.html #}

单个文件

多份个文件

{# multiple参数支持一次性传多个文件 #}

{# index.html #}

单个文件

{{ file_size }}

{{ file_name }}

{{ info }}

{{ file_content_type }}

多个文件

{{ file_sizes }}

{{ file_names }}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值