Ce tutoriel montre la création d'une API backend robuste et sécurisée à l'aide de FastAPI pour gérer les soumissions de formulaires de contact et les relayer vers un canal Discord via des webhooks. Nous aborderons également la configuration cruciale de CORS pour un accès contrôlé.
Prérequis :
Étape 1 : Configuration du projet
Créez un répertoire de projet et installez les packages nécessaires :
pip install fastapi uvicorn httpx python-dotenv
Étape 2 : Création d'une application FastAPI
Créer main.py
:
import os from fastapi import FastAPI, HTTPException from fastapi.middleware.cors import CORSMiddleware from pydantic import BaseModel import httpx app = FastAPI() # CORS Configuration (Security!) app.add_middleware( CORSMiddleware, allow_origins=["https://vicentereyes.org", "https://www.vicentereyes.org"], allow_credentials=True, allow_methods=["*"], allow_headers=["*"], )
Étape 3 : Définition du modèle de données
Utilisez Pydantic pour la structure des données :
class FormData(BaseModel): name: str email: str message: str service: str companyName: str companyUrl: str
Étape 4 : Point final de soumission
Ajoutez le gestionnaire de soumission de formulaire :
@app.post("/submit/") @app.post("/submit") # Handles both /submit and /submit/ async def submit_form(form_data: FormData): try: # Format message for Discord message_content = { "content": f"New form submission:\n" f"**Name:** {form_data.name}\n" f"**Email:** {form_data.email}\n" f"**Message:** {form_data.message}\n" f"**Service:** {form_data.service}\n" f"**Company Name:** {form_data.companyName}\n" f"**Company URL:** {form_data.companyUrl}" } # Send to Discord webhook using httpx async with httpx.AsyncClient() as client: response = await client.post(os.environ["FASTAPI_DISCORD_WEBHOOK_URL"], json=message_content) if response.status_code != 204: raise HTTPException(status_code=response.status_code, detail="Discord message failed") return {"message": "Form data sent successfully"} except Exception as e: raise HTTPException(status_code=500, detail=str(e))
Étape 5 : Variables d'environnement
Créer un fichier .env
:
<code>FASTAPI_DISCORD_WEBHOOK_URL=your_discord_webhook_url_here</code>
Comment ça marche :
Exécution de l'application :
uvicorn main:app --reload
Accédez à l'API sur http://localhost:8000
.
Meilleures pratiques de sécurité :
Exemple d'intégration frontend :
fetch('your_api_url/submit', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ /* form data */ }) });
Conclusion :
Ce backend FastAPI sécurisé fournit une méthode fiable et efficace pour gérer les formulaires de contact et s'intégrer à Discord. L'utilisation d'opérations asynchrones et d'une gestion robuste des erreurs garantit une solution performante et sécurisée.
Code : https://www.php.cn/link/d92d7ec47187a662aacda2d4b4c7628e En direct : https://www.php.cn/link/775bc655c77d679c193f1982dac04668
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!