前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FastAPI 学习之路(四十三)路径操作的高级配置

FastAPI 学习之路(四十三)路径操作的高级配置

作者头像
雷子
发布2021-09-17 11:26:18
3850
发布2021-09-17 11:26:18
举报
文章被收录于专栏:雷子说测试开发

前言

上一篇我们分享了FastAPI 学习之路(四十二)利用Docker部署发布,这次我们分享下路径的高级配置。

正文

在实际的开发中呢,我们可能有些接口呢,不能对比进行开放,比如说我们内部的一些监控的接口,那么我们肯定想着如何在接口文档中进行屏蔽,那么我们看下应该如何实现呢。

代码语言:javascript
复制
@app.get("/legacy/", include_in_schema=False)
def get_legacy_data(response: Response):
    headers = {"X-Cat": "leizi", "Content-Language": "en-US"}
    data = """<?xml version="1.0"?>
    <shampoo>
    <Header>
        Apply shampoo here.
    </Header>
    <Body>
        You'll have to use soap here.
    </Body>r
    </shampoo>
    """
    response.set_cookie(key="message", value="hello")
    return Response(content=data, media_type="application/xml",
                    headers=headers)

其实很简单,只需要配置

代码语言:javascript
复制
include_in_schema=False

即可。那么我们看下接口文档是否有这个接口呢

是没有在接口的文档中展示的,只能供我们自己内部直接调用。我们直接去访问。

接口可以正常返回的。

docstring 的高级描述

路径操作函数 的 docstring 中用于 OpenAPI 的行数。

添加一个 \f (一个「换页」的转义字符)可以使 FastAPI 在那一位置截断用于 OpenAPI 的输出。

我们看下在接口中的具体实现

代码语言:javascript
复制
# 新建用户
@usersRouter.post("/users/", tags=["users"], response_model=Users)
def create_user(user: UserCreate, db: Session = Depends(get_db)):
    """
        - **email**: 用户的邮箱
        - **password**: 用户密码
    """
    db_crest = get_user_emai(db, user.email)
    if not db_crest:
        return db_create_user(db=db, user=user)
    raise HTTPException(status_code=200, detail="账号不能重复")

我们看下最后会返回什么。

我们可以看到,在接口文档中,我们去描述了我们的参数。文档内正常展示了,那么我们可以用这个,对接口的参数进行一些描述后,就可以展示在我们对外的接口文档中,方便去理解每个字段。

后记

发现问题,解决问题。遇到问题,慢慢解决问题即可。

欢迎关注雷子说测试开发,后续将会持续为大家分享更多的技术知识

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-09-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 雷子说测试开发 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档