Erreur CORS dans la requête ReactJS GET avec redirection 302
Vous êtes confronté à une erreur CORS lorsque votre application ReactJS envoie une requête GET à votre backend serveur (b.com) qui répond par une redirection 302 vers une page de connexion SSO (sso.example.com). Vous n'avez pas de contrôle sur les en-têtes de réponse de la page SSO, ce qui signifie que vous ne pouvez pas ajouter l'en-tête Access-Control-Allow-Origin pour résoudre le problème CORS.
Solution :
Pour contourner cette limitation CORS, il est recommandé de gérer la redirection côté client au sein du navigateur. Cela évitera le problème CORS car vous accédez à la page SSO directement à partir de son URL.
Solution JavaScript :
Vous pouvez utiliser du JavaScript simple pour rediriger votre requête GET en utilisant l'objet window :
<code class="javascript">window.location.href = "https://www.example.com";</code>
Cette approche est simple et facile à mettre en œuvre, mais elle peut affecter l'historique de votre navigateur. Alternativement, vous pouvez utiliser la bibliothèque de navigation de React pour gérer la redirection par programme :
<code class="javascript">import { useHistory } from "react-router-dom"; const history = useHistory(); useEffect(() => { history.push("https://www.example.com"); }, []);</code>
Cette méthode vous permet de contrôler la redirection plus précisément et d'éviter tout problème potentiel avec l'historique de navigation. En traitant la redirection côté client, vous éliminez le besoin d'implémenter les en-têtes CORS sur la page SSO, ce qui échappe à votre contrôle.
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!