Maison > Questions et réponses > le corps du texte
J'essaie de restituer une page HTML
qui affiche un flux vidéo provenant d'une webcam. Cependant, je suis confronté à l'erreur suivante :
500 Server Error TypeError: TemplateResponse() missing 1 required positional argument: 'context'
Mon application FastAPI :
from fastapi import FastAPI import uvicorn from fastapi import Depends, FastAPI from fastapi import FastAPI, Request from fastapi.responses import HTMLResponse from fastapi.templating import Jinja2Templates import cv2 app = FastAPI(debug=True) templates = Jinja2Templates(directory="templates") @app.get("/") async def index(): return templates.TemplateResponse("index.html") async def gen_frames(camera_id): cap= cv2.VideoCapture(0) while True: # for cap in caps: # # Capture frame-by-frame success, frame = cap.read() # read the camera frame if not success: break else: ret, buffer = cv2.imencode('.jpg', frame) frame = buffer.tobytes() yield (b'--framern'b'Content-Type: image/jpegrnrn' + frame + b'rn') if __name__ == '__main__': uvicorn.run(app, host="127.0.0.1",port=8000)
Ma page HTML (index.html) :
<!doctype html> <html lang="en"> <head> <!-- Required meta tags --> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> <!-- Bootstrap CSS --> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous"> <title>Multiple Live Streaming</title> </head> <body> <div class="container"> <div class="row"> <div class="col-lg-7"> <h3 class="mt-5">Multiple Live Streaming</h3> <img src="{{ url_for('video_feed', id='0') }}" width="100%"> </div> </div> </div> </body> </html>
Tracback :
P粉8845486192023-10-27 10:49:35
Vous devez transmettre la demande lorsque vous utilisez des modèles.
from fastapi import Request @app.get("/") async def index(request: Request): return templates.TemplateResponse("index.html", {"request": request})
Vous pouvez donc également utiliser StreamingResponse< 将视频作为另一条路径/strong>
from fastapi.responses import StreamingResponse @app.get("/serve/{camera_id}", include_in_schema=False) async def serve_video(camera_id: int): return StreamingResponse(gen_frames(camera_id))
Ensuite, utilisez Ajax ou Axios etc. pour obtenir la réponse.