API接口开发其实特简单,Python FastApi Web 框架教程来了

技术交流、源码分享

目前群友已超过3000人,添加时最好的备注方式为:来源+兴趣方向,技术交流、核心代码分享都搞定。

方式①、添加微信号:dkl88191,备注:来自CSDN+FastApi
方式②、微信搜索公众号:Python学习与数据挖掘,后台回复:FastApi

一、FastApi??

1.FastAPI可以做什么

它由 Sebastian Ramirez 开发

  • 开发网站
  • 开发 web API
  • 做一个测试平台
  • 做一个持续集成工具
  • 生成文档

2.为什么要学习 FastAPI

  • FastAPI的使用方法和设计参考了几十个 python 明星项目 博采众长 吸收各家精华
  • FastAPI和Flask一样简约
  • FastAPI非常新 并且基于python3.6的类型声明系统
  • 自动生成文档
  • 类型声明和数据检验
  • 内置身份认证
  • 性能强
  • 原生支持异步
  • 强大的依赖注入系统
  • GraphQL和WebSocket支持

二、准备工作

1.编译器工具

Python、Pycharm

2.python安装教程

https://www.runoob.com/python/python-install.html

3.pycharm安装教程

runoob.com/w3cnote/pycharm-windows-install.html

4.安装虚拟环境

1、创建项目工程

在这里插入图片描述

2、安装环境

在这里插入图片描述

3、安装fastapi

在这里插入图片描述

三、教程

1.开启服务和接口访问

main.py

import uvicorn
from fastapi import FastAPI

app=FastAPI()

if __name__ == '__main__':
    uvicorn.run(app)

在这里插入图片描述

服务器运行

在这里插入图片描述

在这里插入图片描述

添加接口

在这里插入图片描述

main

import uvicorn
from fastapi import FastAPI

app=FastAPI()

# 添加首页
@app.get("/")
def index():
    return "This is Home Page."

if __name__ == '__main__':
    uvicorn.run(app)

重新运行项目
在这里插入图片描述

在这里插入图片描述

2.json数据

在这里插入图片描述

重新项目

在这里插入图片描述

json数据格式解析

https://www.json.cn/

在这里插入图片描述

3.api文档在线生成

在这里插入图片描述
文档解析
在这里插入图片描述
文档备注信息
在这里插入图片描述

在这里插入图片描述

4.发送请求

POST请求
在这里插入图片描述

使用ApiPost接口测试工具来访问接口

在这里插入图片描述

在这里插入图片描述

定义多种请求格式

在这里插入图片描述

5.获取URL参数

在这里插入图片描述
在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI

app=FastAPI()

@app.get("/user/{id}")
def user(id):
    return {
    
    "id":id}

if __name__ == '__main__':
    uvicorn.run(app)

6.获取请求头参数

在这里插入图片描述

在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI,Header

app=FastAPI()

@app.get("/user")
def user(id, token=Header(None)):
    return {
    
    "id":id,"token":token}

if __name__ == '__main__':
    uvicorn.run(app)

7.表单获取数据

安装包

python-multipart

在这里插入图片描述
在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI,Header,Form

app=FastAPI()

@app.get("/user")
def user(id, token=Header(None)):
    return {
    
    "id":id,"token":token}

@app.post("/login")
def login(username=Form(None),password=Form(None)):
    return {
    
    "data":{
    
    "username":username,"password":password}}

if __name__ == '__main__':
    uvicorn.run(app)

8.自定义返回JSON信息

在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI
from fastapi.responses import JSONResponse

app=FastAPI()

@app.get("/user")
def user():
    return JSONResponse(content={
    
    "msg":"get user"},
                        status_code=202,
                        headers={
    
    "a":"b"})

if __name__ == '__main__':
    uvicorn.run(app)

在这里插入图片描述
在这里插入图片描述

8.自定义返回HTML

在这里插入图片描述
在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI
from fastapi.responses import JSONResponse,HTMLResponse

app=FastAPI()

@app.get("/user")
def user():
    return JSONResponse(content={
    
    "msg":"get user"},
                        status_code=202,
                        headers={
    
    "a":"b"})

@app.get("/")
def user():
    html_content="""
    <html>
        <body><p style="color:red">Hello World</p></body>
        </html>
    """
    return HTMLResponse(content=html_content)

if __name__ == '__main__':
    uvicorn.run(app)

9.自定义返回文件

在这里插入图片描述
在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI
from fastapi.responses import JSONResponse,HTMLResponse
from starlette.responses import FileResponse

app=FastAPI()

@app.get("/user")
def user():
    return JSONResponse(content={
    
    "msg":"get user"},
                        status_code=202,
                        headers={
    
    "a":"b"})

@app.get("/")
def user():
    html_content="""
    <html>
        <body><p style="color:red">Hello World</p></body>
        </html>
    """
    return HTMLResponse(content=html_content)

@app.get("/avatar")
def user():
    avatar='./static/violet.jpg'
    return FileResponse(avatar)

if __name__ == '__main__':
    uvicorn.run(app)

10.自定义返回HTML页面

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI,Request
from fastapi.templating import Jinja2Templates

app=FastAPI()
template=Jinja2Templates("pages")

@app.get("/")
def user(req:Request):
    return template.TemplateResponse("index.html",context={
    
    "request":req})

if __name__ == '__main__':
    uvicorn.run(app)

返回结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

11.代办事项小案例

main.py

在这里插入图片描述

index.html

在这里插入图片描述

运行项目

在这里插入图片描述

main.py

在这里插入图片描述

index.html

在这里插入图片描述

运行项目

在这里插入图片描述

12.绑定数据库

安装 tortoise-orm

在这里插入图片描述

安装 aiomysql

在这里插入图片描述

main.py
在这里插入图片描述

13.数据库访问

在这里插入图片描述

models.py

from tortoise import Model,fields

class Todo(Model):
    id=fields.IntField(pk=True)
    content=fields.CharField(max_length=500)
    create_at=fields.DatetimeField(auto_now_add=True)
    updated_at=fields.DatetimeField(auto_now=True)

在这里插入图片描述

main.py

import uvicorn
from fastapi import FastAPI, Request, Form
from fastapi.responses import RedirectResponse
from starlette.templating import Jinja2Templates
from tortoise.contrib.fastapi import register_tortoise

from dao.models import Todo

app=FastAPI()
template=Jinja2Templates("pages")

# 数据库绑定
register_tortoise(app,db_url="mysql://root:123456@localhost:3306/fastapi",
                  modules={
    
    "models":['dao.models']},
                  add_exception_handlers=True,
                  generate_schemas=True)

todos = ["写日记", "看电影", "玩游戏"]

# 添加首页
@app.get("/")
async def user(req:Request):
    todos=await Todo.all()
    print(todos)
    return template.TemplateResponse("index.html",context={
    
    "request":req,"todos":todos})

@app.post("/todo")
def todo(todo=Form(None)):
    todos.insert(0,todo)
    return RedirectResponse("/",status_code=302)

if __name__ == '__main__':
    uvicorn.run(app)

运行项目
在这里插入图片描述

14.数据库写入

main.py

在这里插入图片描述

运行项目

在这里插入图片描述

数据库里就多了个字段

在这里插入图片描述

此时就是显示有问题

在这里插入图片描述

index.html

在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_38037405/article/details/127182055