引言:
最近工作中有机会接触FastAPI这个框架,所以就把官方文档看了一遍,对框架的各个特性及使用方法做了总结,会逐步的发出来,希望对您有用。
如果您之前接触过python的其他框架,看起来会非常简单和顺畅,其实就是很简单。
【上一篇】:【FastAPI基础】17、文件操作
【下一篇】:【FastAPI基础】18、表单和文件操作
【FastAPI搭建好的产品框架源码,直接上手】:【FastAPI搭建好的产品架构】,直接上手
废话不多说,直接上源码,复制直接用呗,其他的就不粘贴了,没啥特别的。
如有需要help,下面私信我
# encoding: utf-8
"""
@author: 陈建华
@file: views.py
@time: 2021/2/17 11:10
@desc: 文件管理
"""
from typing import List
from fastapi import APIRouter, Depends, BackgroundTasks, HTTPException, Form, File, UploadFile
from server import config
from sqlalchemy.orm import Session
from starlette.responses import RedirectResponse
from starlette.requests import Request
from server.schemas.base import HttpResponseModel
from server.app_file.models.file import BaseFile
from server.utils.database import get_db
from server.utils import check_file
from server.utils.responses import response_code_set
from server.utils.dependencies import verify_token
from fdfs_client.client import *
fds_config = get_tracker_conf(config.FILE_CONF)
client = Fdfs_client(fds_config)
router = APIRouter()
@router.post(
"/upload/",
tags=["文件上傳"],
responses=response_code_set({"code": 200,
"message": "文件上传成功",
"content": {
"name": "QQ截图20201111104820.jpg",
"path": "http://47.105.39.143:20000/group1/M00/00/35/rB88YAAJH0UfP0aY397.jpg",
"type": "jpg",
"size": "145.95KB",
"notes": "QQ截图20201111104820.jpg",
"id": 2
}
})
)
async def views_base(
file: UploadFile = File(...), # 接收文件流
db: Session = Depends(get_db) # 实例数据库对象
):
code, content, message = 200, {}, u''
try:
if not file:
code, content, message = 404, {}, u'file 缺失'
elif not check_file.check_file_type(file.filename, 'file_all'):
code, content, message = 404, {}, u'不允许的文件格式'
elif not check_file.check_file_size(file.spool_max_size, 'file'):
code, content, message = 404, {}, u'文件大小超出服务器限制'
else:
file_name = file.filename # 文件名
file_type = file_name.split('.')[1] # 文件类型
ret = client.upload_by_buffer(file.file.read(), file_type) # 调用fastfdfs上传文件流
remote_file_id = str(ret['Remote file_id'], encoding='utf8') # 拿到返回值
path = config.FILE_SERVER_IP + ':' + config.FILE_DOWNLOAD_PORT + '/' + remote_file_id # 拼接返回值
size = ret['Uploaded size'] # 文件大小
# 将信息入库
file_obj = await BaseFile.insert(db=db, name=file_name, path=path, type=file_type, size=size,
notes=file_name)
code, content, message = 200, file_obj, u'文件上传成功'
except Exception as e:
code, content, message = 405, {}, u'上传失败:{}'.format(e)
finally:
return HttpResponseModel(code=code, message=message, content=content)