Table des matières
1. JSONP
二、代理模式
三、CORS
Maison développement back-end tutoriel php Résumer trois méthodes d'implémentation inter-domaines Ajax en PHP

Résumer trois méthodes d'implémentation inter-domaines Ajax en PHP

Apr 04, 2023 am 09:12 AM

Avec la popularité de la séparation front-end et back-end, il est devenu courant dans le développement Web que le front-end appelle l'interface back-end et obtienne des données via la technologie Ajax.

Cependant, en raison de la même politique d'origine du navigateur, les pages Web provenant de sources différentes (différents protocoles, noms de domaine ou ports) ne peuvent pas accéder les unes aux autres au DOM et aux cookies, ce qui fait de l'accès entre domaines une exigence très courante. Il existe de nombreuses façons de résoudre ce problème.

Cet article présentera trois façons d'implémenter Ajax multi-domaines en PHP.

1. JSONP

JSONP (JSON with Padding) est une solution très populaire lorsque le front-end lance des requêtes inter-domaines. Il s'agit en fait d'un moyen de « tromper » le navigateur, en profitant du fait que la balise <script> n'a aucune restriction inter-domaines pour obtenir un accès inter-domaines. Son principe est de générer dynamiquement un extrait de code JavaScript pour répondre à la requête côté serveur. L'extrait de code appellera une fonction JavaScript avec un nom spécifique (nom de la fonction de rappel) et lui transmettra en paramètre les données traitées par le serveur. cette fonction. Cela permet d'obtenir l'effet d'un accès inter-domaines. <script> 标签没有跨域限制的特点来实现跨域访问。它的原理就是通过在服务端动态生成用于响应请求的 JavaScript 代码片段,该代码片段会调用一个特定名称(回调函数名)的 JavaScript 函数,并将服务端处理的数据作为参数传递给此函数,从而达到跨域访问的效果。

JSONP 的使用方式如下:

  1. 客户端代码:
function handleJsonp(data) {
  console.log(data);
}
const script = document.createElement('script');
script.src = 'http://example.com/api?callback=handleJsonp';
document.head.appendChild(script);
Copier après la connexion
  1. 服务端代码:
<?php
$data = array(&#39;foo&#39; => 'bar');
$callback = $_GET['callback'];
echo sprintf('%s(%s);', $callback, json_encode($data));
?>
Copier après la connexion

在这段代码中,服务端的返回结果是一个包含回调函数调用的 JavaScript 代码片段,客户端得到数据后会自动执行回调函数,并将服务端返回的数据作为回调函数的参数。

JSONP 的优点是兼容性好,兼容性只受到浏览器支持 <script> 标签的程度限制,但缺点是存在安全性问题,因为回调函数是在客户端执行的,我们无法保证此函数所执行的是我们期望的逻辑,如果恶意回调函数传递了恶意代码,就会存在被 XSS 攻击的风险。

二、代理模式

代理模式是另一种比较流行的跨域解决方案。它的基本思路是在服务端设置一个代理访问指定网址,然后将从代理服务器获取到的数据返回给客户端。通过这种方式,客户端可以直接访问同源的代理服务器,代理服务器再去访问跨域的目标服务器,并将目标服务器返回的数据进行中转。

代理模式的使用方式如下:

  1. 客户端代码:
fetch('http://example.com/proxy_api')
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error(error));
Copier après la connexion
  1. 服务端代码:
<?php
$url = &#39;http://example.com/api&#39;;
$data = json_decode(file_get_contents($url), true);
echo json_encode($data);
?>
Copier après la connexion

在这段代码中,客户端的请求被发往代理服务器,代理服务器在得到目标服务器返回的数据后将之返回给客户端,这样就实现了客户端对跨域服务的访问。

代理模式的优点是安全性好,因为在客户端只会访问同源的代理服务器,代理服务器再去访问跨域的目标服务器,从而有效避免了跨域访问带来的安全风险,但缺点是需要额外开发服务器端代码,增加了额外的工作量和开发成本。

三、CORS

CORS 是目前最流行的跨域访问解决方案。它通过在服务端设置响应头来告诉客户端是否允许跨域访问,从而实现跨域访问安全控制。

CORS 的使用方式如下:

  1. 客户端代码:
fetch('http://example.com/api', {
  mode: 'cors'
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error(error));
Copier après la connexion
  1. 服务端代码:
<?php
header(&#39;Access-Control-Allow-Origin: *&#39;);
$data = array(&#39;foo&#39; => 'bar');
echo json_encode($data);
?>
Copier après la connexion

在这段代码中,服务端设置了 Access-Control-Allow-Origin:* 响应头,表示允许所有来源访问该接口,客户端通过在请求中设置 mode: 'cors'

JSONP s'utilise comme suit :

  1. Code client :
rrreee
  1. Code serveur :
rrreee Dans ce code, le résultat renvoyé par le serveur est un fragment de code JavaScript qui contient un appel de fonction de rappel une fois que le client a obtenu les données, il exécutera automatiquement la fonction de rappel et utilisera les données renvoyées par le serveur comme paramètre du. fonction de rappel.

L'avantage de JSONP est une bonne compatibilité. La compatibilité n'est limitée que par la mesure dans laquelle le navigateur prend en charge la balise <script>. Cependant, l'inconvénient est qu'il existe des problèmes de sécurité dus au rappel. est exécutée sur le client. , nous ne pouvons pas garantir que cette fonction exécute la logique attendue. Si la fonction de rappel malveillante transmet du code malveillant, il y aura un risque d'être attaqué par XSS. 🎜🎜2. Mode proxy 🎜🎜Le mode proxy est une autre solution inter-domaines populaire. Son idée de base est de configurer un proxy sur le serveur pour accéder à l'URL spécifiée, puis de renvoyer les données obtenues du serveur proxy au client. De cette manière, le client peut accéder directement au serveur proxy à partir de la même origine, et le serveur proxy accède ensuite au serveur cible inter-domaines et transmet les données renvoyées par le serveur cible. 🎜🎜Le mode proxy s'utilise de la manière suivante : 🎜
  1. Code client :
rrreee
  1. Code serveur :
  2. ol >rrreee🎜Dans ce code, la requête du client est envoyée au serveur proxy. Le serveur proxy renvoie les données renvoyées par le serveur cible au client, réalisant ainsi l'accès du client aux services inter-domaines. 🎜🎜L'avantage du mode proxy est une bonne sécurité, car le client n'accédera qu'au serveur proxy de même origine, et le serveur proxy accédera ensuite au serveur cible inter-domaine, évitant ainsi efficacement les risques de sécurité causés par l'inter-domaine. accès, mais il présente les inconvénients. Il nécessite un développement supplémentaire du code côté serveur, ce qui augmente la charge de travail et les coûts de développement supplémentaires. 🎜🎜3. CORS🎜🎜CORS est actuellement la solution d'accès inter-domaines la plus populaire. Il définit l'en-tête de réponse côté serveur pour indiquer au client s'il doit autoriser l'accès entre domaines, réalisant ainsi un contrôle de sécurité d'accès entre domaines. 🎜🎜CORS s'utilise comme suit : 🎜
    1. Code client :
    rrreee
    1. Code serveur :
    rrreee 🎜Dans ce code, le serveur définit l'en-tête de réponse Access-Control-Allow-Origin:*, indiquant que toutes les sources sont autorisées à accéder à l'interface. Le client définit en mode requête : Paramètre 'cors' pour informer le navigateur que la requête sera accessible sur tous les domaines. 🎜🎜L'avantage de CORS est qu'il prend en charge nativement et ne nécessite pas de travail de développement supplémentaire. Cependant, son inconvénient est qu'il ne prend pas en charge IE8/9 et doit être pris en charge côté serveur. de noms de sous-domaines. 🎜🎜Ci-dessus sont les trois méthodes inter-domaines pour implémenter Ajax en PHP Dans les projets réels, vous devez choisir la solution inter-domaines la plus appropriée en fonction de la situation spécifique. 🎜

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

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)

Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Comment fonctionne le détournement de session et comment pouvez-vous l'atténuer en PHP? Comment fonctionne le détournement de session et comment pouvez-vous l'atténuer en PHP? Apr 06, 2025 am 12:02 AM

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

Décrivez les principes solides et comment ils s'appliquent au développement de PHP. Décrivez les principes solides et comment ils s'appliquent au développement de PHP. Apr 03, 2025 am 12:04 AM

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système? Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système? Mar 31, 2025 pm 11:54 PM

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

Comment déboguer le mode CLI dans phpstorm? Comment déboguer le mode CLI dans phpstorm? Apr 01, 2025 pm 02:57 PM

Comment déboguer le mode CLI dans phpstorm? Lors du développement avec PHPStorm, nous devons parfois déboguer PHP en mode interface de ligne de commande (CLI) ...

Expliquez la liaison statique tardive en PHP (statique: :). Expliquez la liaison statique tardive en PHP (statique: :). Apr 03, 2025 am 12:04 AM

Liaison statique (statique: :) ​​implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Comment envoyer une demande post contenant des données JSON à l'aide de la bibliothèque Curl de PHP? Comment envoyer une demande post contenant des données JSON à l'aide de la bibliothèque Curl de PHP? Apr 01, 2025 pm 03:12 PM

Envoyant des données JSON à l'aide de la bibliothèque Curl de PHP dans le développement de PHP, il est souvent nécessaire d'interagir avec les API externes. L'une des façons courantes consiste à utiliser la bibliothèque Curl pour envoyer le post� ...

See all articles