从零到fastapi英雄:我的hngstage dventure(英雄.fastapi.dventure.hngstage...)
从零构建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的详细内容,更多请关注知识资源分享宝库其它相关文章!