■ Request 클래스를 사용해 메소드에서 HTTP Request 객체를 직접 참조하는 방법을 보여준다.
• FastAPI는 내부적으로 Starlette를 사용하고 있다.
• 필요하다면 FastAPI 대신 Starlette의 Request 객체를 직접 참조할 수 있다.
• Request 객체를 직접 참조하면, FastAPI에 의해 유효성 검사와 문서화가 되지 않는다.
▶ main.py
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
import uvicorn from fastapi import FastAPI, Request fastAPI = FastAPI() @fastAPI.get("/test/{testID}") def getData(testID : int, request : Request): return { "client_host" : request.client.host, "testID" : testID } if __name__ == "__main__": uvicorn.run("main:fastAPI") |
▶ 테스트
1 2 3 |
▶ requirements.txt
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
annotated-types==0.7.0 anyio==4.4.0 certifi==2024.6.2 click==8.1.7 dnspython==2.6.1 email_validator==2.1.1 exceptiongroup==1.2.1 fastapi==0.111.0 fastapi-cli==0.0.4 h11==0.14.0 httpcore==1.0.5 httptools==0.6.1 httpx==0.27.0 idna==3.7 Jinja2==3.1.4 markdown-it-py==3.0.0 MarkupSafe==2.1.5 mdurl==0.1.2 orjson==3.10.3 pydantic==2.7.3 pydantic_core==2.18.4 Pygments==2.18.0 python-dotenv==1.0.1 python-multipart==0.0.9 PyYAML==6.0.1 rich==13.7.1 shellingham==1.5.4 sniffio==1.3.1 starlette==0.37.2 typer==0.12.3 typing_extensions==4.12.2 ujson==5.10.0 uvicorn==0.30.1 uvloop==0.19.0 watchfiles==0.22.0 websockets==12.0 |
※ pip install fastapi uvicorn 명령을 실행했다.