Maison >interface Web >js tutoriel >Comment puis-je utiliser AJAX pour récupérer des données à partir de domaines externes ?

Comment puis-je utiliser AJAX pour récupérer des données à partir de domaines externes ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-28 05:10:11837parcourir

How Can I Use AJAX to Retrieve Data from External Domains?

Requêtes AJAX inter-domaines : exploration des solutions de contournement

AJAX a révolutionné le développement Web, permettant des applications dynamiques et interactives. Cependant, un obstacle courant survient lorsque l'on tente d'effectuer des requêtes HTTP inter-domaines en raison des mesures de sécurité du navigateur. Cet article explore des solutions alternatives pour surmonter cette limitation et récupérer des données à partir de domaines externes.

Énoncé du problème

La question met en évidence l'incapacité d'effectuer directement des appels AJAX vers des domaines externes comme "http://www.google.com" et récupérer les résultats sur son propre site Internet. Bien que l'utilisation du type de données "jsonp" puisse sembler une solution, le manque de formatage JSON des données reçues entraîne des erreurs de syntaxe.

Solution : intégration du serveur proxy

Le recommandé La solution consiste à utiliser un langage côté serveur comme proxy. Ce proxy agit comme intermédiaire, récupérant les données du domaine externe et les renvoyant au site Web du client dans un format approprié. Voici un exemple d'implémentation utilisant jQuery :

$.ajax({
    url: 'proxy.php',
    type: 'POST',
    data: {
        address: 'http://www.google.com'
    },
    success: function(response) {
        // response now contains full HTML of google.com
    }
});

PHP correspondant (proxy.php) pour récupérer et renvoyer les données :

echo file_get_contents($_POST['address']);

Considérations iFrame

iFrames adhère également à la même politique de requêtes inter-domaines. Ainsi, l'intégration d'un iFrame provenant d'un domaine différent ne permettra pas la récupération ou la manipulation directe des données.

Conclusion

En tirant parti d'un serveur proxy, il est possible de contourner les -restrictions de domaine et récupérer des données à partir de destinations externes à l'aide d'AJAX. Cette méthode offre une solution simple et efficace, permettant aux développeurs de créer des applications qui interagissent de manière transparente avec le contenu de plusieurs domaines.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn