
从零构建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
祝大家编程愉快!










