Qu'est-ce que JSONP ?
JSONP, ou « JSON avec remplissage », est une technique qui permet l'échange de données JSON entre différents domaines. Ceci est particulièrement utile lorsqu'une application Web sur un domaine doit accéder aux données d'un serveur sur un domaine différent.
Pourquoi JSONP a-t-il été créé ?
Requêtes inter-domaines ne sont généralement pas autorisés par les navigateurs pour des raisons de sécurité. Cependant, JSONP surmonte cette limitation en utilisant des balises de script, qui ne sont pas soumises aux mêmes restrictions.
Comment fonctionne JSONP
Pour activer JSONP, un paramètre de rappel est inclus dans l'URL de la demande. Ce paramètre spécifie une fonction côté client qui gérera les données JSON reçues.
Le serveur répond avec les données JSON incluses dans un appel de fonction, appelant la fonction de rappel désignée. Par exemple, si le paramètre de rappel est « myCallback », la réponse du serveur peut ressembler à ceci :
myCallback({ foo: 'bar' });
Avantages et limites de JSONP
JSONP fournit une méthode simple moyen de faire des requêtes inter-domaines. Cependant, il présente certaines limites :
Alternatives à JSONP
CORS (Cross-Origin Resource Sharing) est une approche plus sécurisée et moderne pour les requêtes inter-domaines. Il offre un contrôle précis sur la requête et est préféré à JSONP dans la plupart des cas.
Conclusion
JSONP était une solution de contournement intelligente pour faciliter les requêtes inter-domaines lorsque CORS n’a pas été largement soutenu. Cependant, avec la disponibilité de CORS, il est généralement recommandé d'utiliser CORS car il offre une sécurité et un contrôle supérieurs. Néanmoins, JSONP reste une technique utile dans certaines situations, notamment pour supporter les anciens navigateurs.
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!