Table des matières
2. Qu'est-ce que JSONP
3. Utilisation de JSONP
Exemples d'utilisation front-end
Exemple de coopération backend
Principe JQuery Ajax Jsonp
1. Qu'est-ce que l'accès inter-domaines
Exemple d'utilisation front-end
Maison interface Web js tutoriel Analyser l'accès inter-domaines jsonp du point de vue front-end et back-end

Analyser l'accès inter-domaines jsonp du point de vue front-end et back-end

Sep 13, 2018 pm 05:02 PM
js

Extension pour vérifier la légalité en php5. En PHP5.2, la légalité peut être vérifiée via le filtre d'extension intégré.

1. Qu'est-ce que l'accès inter-domaines

Par exemple  : Dans le site Web A, nous espérons utiliser Ajax pour obtenir un contenu spécifique dans le site Web B. Si le site Web A et le site Web B ne se trouvent pas dans le même domaine, il y aura alors un problème d'accès entre domaines. Vous pouvez comprendre que deux noms de domaine ne peuvent pas envoyer de requêtes ou demander des données entre noms de domaine, sinon cela serait dangereux. L'accès inter-domaines viole la même politique d'origine. Pour des informations détaillées sur la même politique d'origine, vous pouvez cliquer sur le lien suivant : Same-origin_policy

Bref, la même politique d'origine stipule que l'ajax du navigateur peut ; accédez uniquement à la même page HTML que ses ressources source (même nom de domaine ou IP).

2. Qu'est-ce que JSONP

JSONP (JSON with Padding) est un "mode d'utilisation" de JSON qui peut être utilisé pour résoudre le problème de l'accès aux données inter-domaines par le grand public. navigateurs.

En raison de la politique de même origine, d'une manière générale, les pages Web situées sur server1.example.com ne peuvent pas communiquer avec des serveurs autres que server1.example.com, et l'élément <script> du HTML est une exception. Grâce à cette stratégie ouverte de l'élément <script>, les pages Web peuvent obtenir des données JSON générées dynamiquement à partir d'autres sources, et ce modèle d'utilisation est ce qu'on appelle JSONP. Les données capturées avec JSONP ne sont pas du JSON, mais du JavaScript arbitraire, qui est exécuté avec un interpréteur JavaScript au lieu d'être analysé avec un analyseur JSON. Des principes plus spécifiques nécessitent plus d'espace pour être expliqués et vous pouvez vous rendre à Baidu par vous-même.

3. Utilisation de JSONP

Exemples d'utilisation front-end

JQuery Ajax encapsule très bien JSONP et il est très pratique pour nous de l'utiliser. Exemple front-end :

    $.ajax({
            type:"GET",
            url:"http://www.deardull.com:9090/getMySeat", //访问的链接
            dataType:"jsonp",  //数据格式设置为jsonp
            jsonp:"callback",  //Jquery生成验证参数的名称
            success:function(data){  //成功的回调函数
                alert(data);
            },
            error: function (e) {
                alert("error");
            }
        });
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Ce qu'il faut noter est :

  • dataType, ce paramètre doit être défini sur jsonp

  • jsonp, la valeur de ce paramètre doit être convenue avec le serveur, les détails sont présentés ci-dessous. (La valeur par défaut conventionnelle est le rappel)

Exemple de coopération backend

Principe JQuery Ajax Jsonp

Pour utiliser jsonp avec le backend, vous devez d'abord Comprendre une fonctionnalité de Jquery Ajax jsonp :
Lorsque Jquery envoie une requête Ajax jsonp, il ajoutera automatiquement un paramètre de vérification après le lien d'accès. Ce paramètre est généré aléatoirement par Jquery, comme le lien
http://www.deardull.com:9090/getMySeat?callback=jQuery31106628680598769732_1512186387045&amp;_=1512186387046 < In. 🎜>, le paramètre
est automatiquement ajouté par jquery. callback=jQuery31106628680598769732_1512186387045&amp;_=1512186387046Le but de l'ajout de ce paramètre est d'identifier de manière unique cette demande. Lorsque le serveur reçoit la requête, il doit construire la valeur du paramètre avec la valeur json réelle à renvoyer (comment la construire est expliquée ci-dessous), et la renvoyer, et le front-end vérifiera ce paramètre si c'est le cas. le paramètre qu'il a envoyé auparavant, alors les données seront reçues et analysées. Si ce n'est pas ce paramètre, elles seront rejetées.
Ce qui nécessite une attention particulière, c'est le nom de ce paramètre de vérification (j'ai perdu 2 heures sur ce pit). Ce nom vient de la valeur du paramètre front-end
jsonp. Si la valeur du paramètre jsonp frontal est modifiée en "aaa", alors le paramètre correspondant doit être aaa=jQuery31106628680598769732_1512186387045&_=1512186387046

Réception et traitement back-end

I Connaître Jquery A jaxJsonp Le principe et les paramètres à accepter sont connus, et nous pouvons écrire le programme côté serveur.

Afin de coopérer avec json, ce que le serveur doit faire peut être résumé en deux étapes :

La première étape consiste à recevoir les paramètres de vérification
Recevoir la vérification selon le paramètre jsonp nom convenu avec les paramètres Ajax front-end, les exemples sont les suivants (en utilisant SpringMVC, les principes d'autres langages et frameworks sont similaires)

    @ResponseBody
    @RequestMapping(&quot;/getJsonp&quot;)
    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
Copier après la connexion
Copier après la connexion
La deuxième étape consiste à construire les paramètres et à renvoyer
Comparez le rappel du paramètre de vérification reçu avec celui réel à renvoyer. Les données json sont construites selon la méthode "callback(json)" :

     @ResponseBody
    @RequestMapping(&quot;/getMySeat&quot;)    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
        Gson gson=new Gson();   //google的一个json工具库
        Map&lt;String,String&gt; map=new HashMap&lt;&gt;();        map.put(&quot;seat&quot;,&quot;1_2_06_12&quot;);        return callback+&quot;(&quot;+gson.toJson(map)+&quot;)&quot;;   //构造返回值
    }
Copier après la connexion
Copier après la connexion
4. Résumé

Enfin, le code correspondant du front et du back end devrait ressembler à ceci :


Front end

    $.ajax({
            type:&quot;GET&quot;,
            url:&quot;http://www.deardull.com:9090/getMySeat&quot;, //访问的链接
            dataType:&quot;jsonp&quot;,  //数据格式设置为jsonp
            jsonp:&quot;callback&quot;,  //Jquery生成验证参数的名称
            success:function(data){  //成功的回调函数
                alert(data);
            },
            error: function (e) {
                alert(&quot;error&quot;);
            }
        });
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Backend

    @ResponseBody
    @RequestMapping(&quot;/getMySeat&quot;)    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
        Gson gson=new Gson();        Map&lt;String,String&gt; map=new HashMap&lt;&gt;();        map.put(&quot;seat&quot;,&quot;1_2_06_12&quot;);
        logger.info(callback);        return callback+&quot;(&quot;+gson.toJson(map)+&quot;)&quot;;
    }
Copier après la connexion
Copier après la connexion
Ce qu'il faut noter est :

  • Attention front-end et back-end Pour communiquer la valeur convenue de jsonp, le rappel est généralement utilisé par défaut.

  • Une fois que le backend a obtenu les paramètres en fonction du nom du paramètre jsonp, il doit être construit de manière "callback(json)" avec les données json à renvoyer.

  • Si vous souhaitez tester, pensez à le faire dans un environnement cross-domain (deux machines).

L'exemple complet est constitué des deux morceaux de code ci-dessus, et la connexion Github n'est pas fournie ici. L'exemple ci-dessus a été testé par moi-même et est efficace. Si vous rencontrez des problèmes, veuillez laisser un message pour poser des questions.



1. Qu'est-ce que l'accès inter-domaines

Par exemple  : Dans le site Web A, nous espérons utiliser Ajax pour obtenir un contenu spécifique dans le site Web B. Si le site Web A et le site Web B ne se trouvent pas dans le même domaine, il y aura alors un problème d'accès entre domaines. Vous pouvez comprendre que deux noms de domaine ne peuvent pas envoyer de requêtes ou demander des données entre noms de domaine, sinon cela serait dangereux. L'accès entre domaines viole la politique de même origine. Pour des informations détaillées sur la politique de même origine, vous pouvez cliquer sur le lien suivant : Same-origin_policy
En bref, la politique de même origine stipule que l'ajax du navigateur peut accéder uniquement à la même origine (même origine) que les ressources de sa page HTML (Nom de domaine ou IP).

2. Qu'est-ce que JSONP

JSONP (JSON with Padding) est un "mode d'utilisation" de JSON qui peut être utilisé pour résoudre le problème de l'accès aux données inter-domaines par le grand public. navigateurs.

En raison de la politique de même origine, d'une manière générale, les pages Web situées sur server1.example.com ne peuvent pas communiquer avec des serveurs autres que server1.example.com, et l'élément &lt;script&gt; du HTML est une exception. Grâce à cette stratégie ouverte de l'élément &lt;script&gt;, les pages Web peuvent obtenir des données JSON générées dynamiquement à partir d'autres sources, et ce modèle d'utilisation est ce qu'on appelle JSONP. Les données capturées avec JSONP ne sont pas du JSON, mais du JavaScript arbitraire, qui est exécuté avec un interpréteur JavaScript au lieu d'être analysé avec un analyseur JSON. Des principes plus spécifiques nécessitent plus d'espace pour être expliqués et vous pouvez vous rendre à Baidu par vous-même.

3. Utilisation de JSONP

Exemple d'utilisation front-end

JQuery Ajax encapsule très bien JSONP, et il est très pratique pour nous de l'utiliser. Exemple front-end :

    $.ajax({
            type:&quot;GET&quot;,
            url:&quot;http://www.deardull.com:9090/getMySeat&quot;, //访问的链接
            dataType:&quot;jsonp&quot;,  //数据格式设置为jsonp
            jsonp:&quot;callback&quot;,  //Jquery生成验证参数的名称
            success:function(data){  //成功的回调函数
                alert(data);
            },
            error: function (e) {
                alert(&quot;error&quot;);
            }
        });
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Ce qu'il faut noter est :

  • dataType, ce paramètre doit être défini sur jsonp

  • jsonp, la valeur de ce paramètre doit être convenue avec le serveur, les détails sont présentés ci-dessous. (La valeur par défaut conventionnelle est le rappel)

Exemple de coopération backend

Principe JQuery Ajax Jsonp

Pour utiliser jsonp avec le backend, vous devez d'abord Comprendre une fonctionnalité de Jquery Ajax jsonp :
Lorsque Jquery envoie une requête Ajax jsonp, il ajoutera automatiquement un paramètre de vérification après le lien d'accès. Ce paramètre est généré aléatoirement par Jquery, comme le lien
http://www.deardull.com:9090/getMySeat?callback=jQuery31106628680598769732_1512186387045&amp;_=1512186387046 < In. 🎜>, le paramètre
est automatiquement ajouté par jquery. callback=jQuery31106628680598769732_1512186387045&amp;_=1512186387046Le but de l'ajout de ce paramètre est d'identifier de manière unique cette demande. Lorsque le serveur reçoit la requête, il doit construire la valeur du paramètre avec la valeur json réelle à renvoyer (comment la construire est expliquée ci-dessous), et la renvoyer, et le front-end vérifiera ce paramètre si c'est le cas. le paramètre qu'il a envoyé auparavant, alors les données seront reçues et analysées. Si ce n'est pas ce paramètre, elles seront rejetées.
Ce qui nécessite une attention particulière, c'est le nom de ce paramètre de vérification (j'ai perdu 2 heures sur ce pit). Ce nom vient de la valeur du paramètre front-end
jsonp. Si la valeur du paramètre jsonp frontal est modifiée en "aaa", alors le paramètre correspondant doit être aaa=jQuery31106628680598769732_1512186387045&_=1512186387046

Réception et traitement back-end

I Connaître Jquery A jaxJsonp Le principe et les paramètres à accepter sont connus, et nous pouvons écrire le programme côté serveur.

Afin de coopérer avec json, ce que le serveur doit faire peut être résumé en deux étapes :

La première étape consiste à recevoir les paramètres de vérification
Recevoir la vérification selon le paramètre jsonp nom convenu avec les paramètres Ajax front-end, les exemples sont les suivants (en utilisant SpringMVC, d'autres langages​​et frameworks ont des principes similaires)

    @ResponseBody
    @RequestMapping(&quot;/getJsonp&quot;)
    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
Copier après la connexion
Copier après la connexion
La deuxième étape consiste à construire les paramètres et à renvoyer
Comparez le rappel du paramètre de vérification reçu avec celui réel à renvoyer. Les données json sont construites selon la méthode "callback(json)" :

     @ResponseBody
    @RequestMapping(&quot;/getMySeat&quot;)    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
        Gson gson=new Gson();   //google的一个json工具库
        Map&lt;String,String&gt; map=new HashMap&lt;&gt;();        map.put(&quot;seat&quot;,&quot;1_2_06_12&quot;);        return callback+&quot;(&quot;+gson.toJson(map)+&quot;)&quot;;   //构造返回值
    }
Copier après la connexion
Copier après la connexion
4. Résumé

Enfin, le code correspondant du front et du back end devrait ressembler à ceci :


Front end

    $.ajax({
            type:&quot;GET&quot;,
            url:&quot;http://www.deardull.com:9090/getMySeat&quot;, //访问的链接
            dataType:&quot;jsonp&quot;,  //数据格式设置为jsonp
            jsonp:&quot;callback&quot;,  //Jquery生成验证参数的名称
            success:function(data){  //成功的回调函数
                alert(data);
            },
            error: function (e) {
                alert(&quot;error&quot;);
            }
        });
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Backend

    @ResponseBody
    @RequestMapping(&quot;/getMySeat&quot;)    public String getMySeatSuccess(@RequestParam(&quot;callback&quot;) String callback){
        Gson gson=new Gson();        Map&lt;String,String&gt; map=new HashMap&lt;&gt;();        map.put(&quot;seat&quot;,&quot;1_2_06_12&quot;);
        logger.info(callback);        return callback+&quot;(&quot;+gson.toJson(map)+&quot;)&quot;;
    }
Copier après la connexion
Copier après la connexion
Ce qu'il faut noter est :

  • Attention front-end et back-end Pour communiquer la valeur convenue de jsonp, le rappel est généralement utilisé par défaut.

  • Une fois que le backend a obtenu les paramètres en fonction du nom du paramètre jsonp, il doit être construit de manière "callback(json)" avec les données json à renvoyer.

Recommandations associées :

PHP 1 doute sur AJAX

class.rFastTemplate.php one_PHP tutoriel


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 de ce site Web
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

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser JS et Baidu Maps pour implémenter la fonction Map Pan Comment utiliser JS et Baidu Maps pour implémenter la fonction Map Pan Nov 21, 2023 am 10:00 AM

Comment utiliser JS et Baidu Maps pour implémenter la fonction Map Pan

Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies avec PHP et JS Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies avec PHP et JS Dec 17, 2023 pm 06:55 PM

Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies avec PHP et JS

Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Apr 03, 2024 am 11:55 AM

Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS

Conseils de développement PHP et JS : maîtrisez la méthode de création de graphiques en bougies boursières Conseils de développement PHP et JS : maîtrisez la méthode de création de graphiques en bougies boursières Dec 18, 2023 pm 03:39 PM

Conseils de développement PHP et JS : maîtrisez la méthode de création de graphiques en bougies boursières

Comment créer un graphique en chandeliers boursiers en utilisant PHP et JS Comment créer un graphique en chandeliers boursiers en utilisant PHP et JS Dec 17, 2023 am 08:08 AM

Comment créer un graphique en chandeliers boursiers en utilisant PHP et JS

Comment utiliser JS et Baidu Maps pour implémenter la fonction de dessin de polygones de carte Comment utiliser JS et Baidu Maps pour implémenter la fonction de dessin de polygones de carte Nov 21, 2023 am 10:53 AM

Comment utiliser JS et Baidu Maps pour implémenter la fonction de dessin de polygones de carte

Comment utiliser JS et Baidu Map pour implémenter la fonction de traitement des événements de clic sur la carte Comment utiliser JS et Baidu Map pour implémenter la fonction de traitement des événements de clic sur la carte Nov 21, 2023 am 11:11 AM

Comment utiliser JS et Baidu Map pour implémenter la fonction de traitement des événements de clic sur la carte

Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte Nov 21, 2023 am 09:33 AM

Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte

See all articles