从零到fastapi英雄:我的hngstage dventure(英雄.fastapi.dventure.hngstage...)

wufei1232025-02-15python16

从零到fastapi英雄:我的hngstage dventure

从零构建FastAPI应用:我的HNG Stage 0 项目实战

各位后端开发者们,大家好!

本文记录了我完成HNG Stage 0 项目的历程,一个使用FastAPI构建的简单API。这个API实现了三个功能:返回我的注册邮箱、显示当前UTC时间(ISO 8601格式)以及提供项目GitHub仓库链接。

项目目标:

任务很明确:创建一个公共API,返回包含以下信息的JSON数据包:

  • 邮箱地址(我的HNG注册邮箱)
  • 当前UTC时间
  • 项目GitHub仓库链接

我选择了Python和FastAPI,因为它易于上手,开发和部署都非常便捷。

API开发:

首先,我创建了一个虚拟环境并安装了FastAPI和Uvicorn。代码如下:

from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware
from datetime import datetime, timezone

app = FastAPI()

app.add_middleware(
    CORSMiddleware,
    allow_origins=["*"],
    allow_credentials=True,
    allow_methods=["GET"],
    allow_headers=["*"],
)

@app.get("/")
def get_info():
    return {
        "email": "joseph.adamu.it@gmail.com",
        "current_datetime": datetime.now(timezone.utc).isoformat(),
        "github_url": "https://github.com/joe-encodes/fastapi-project"
    }

if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="0.0.0.0", port=8000)

代码说明:

  • FastAPI 框架用于构建API。
  • CORSMiddleware 中间件允许跨域请求。
  • get_info 函数返回包含所需信息的JSON数据。

测试与部署:

本地测试通过后,我将代码推送到GitHub,并使用Render进行部署。部署配置如下:

  • 构建命令:pip install -r requirements.txt
  • 启动命令:uvicorn main:app --host 0.0.0.0 --port 10000

API成功部署,并可公开访问。

经验总结:

这次项目经历让我学习到:

  • FastAPI 的高效易用性。
  • 跨域请求处理的重要性。
  • 云平台部署的流程和技巧。

这个HNG Stage 0 项目不仅仅是代码的编写,更是对问题解决能力和部署能力的考验。希望我的经验能帮助到其他开发者。

联系方式:

  • GitHub: joe-encodes
  • LinkedIn: Joseph Adamu
  • 邮箱: joseph.adamu.it@gmail.com

祝大家编程愉快!

以上就是从零到fastapi英雄:我的hngstage dventure的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。