Il y a un problème qui a récemment troublé de nombreux développeurs PHP, c'est-à-dire que l'intranet est accessible depuis le réseau externe, mais n'est pas accessible depuis le réseau interne. Ce problème peut être délicat, mais il n’est pas si difficile à résoudre.
Tout d’abord, nous devons comprendre la cause de ce problème. Lorsque nous accédons au réseau externe depuis le réseau interne, nous y accédons généralement via la conversion NAT. La conversion NAT mappera non seulement l'adresse IP du réseau externe au réseau interne, mais mappera également le port demandé. Cependant, lors de l'accès au réseau interne depuis le réseau externe, l'adresse IP du réseau interne étant une IP privée, elle n'est pas directement accessible par le réseau externe. Par conséquent, nous devons effectuer un proxy inverse pour permettre au réseau externe d'accéder au réseau interne.
Voyons comment résoudre ce problème. Supposons que le nom de domaine de notre réseau externe soit « www.example.com » et que l'adresse IP du réseau interne soit « 192.168.1.100 », nous pouvons alors résoudre ce problème en déployant un service proxy inverse sur le réseau externe. Ceci peut être réalisé en utilisant des serveurs proxy inverses courants comme Nginx ou Apache.
Sur Nginx, nous pouvons implémenter un proxy inverse en éditant le fichier de configuration Nginx. Tout d'abord, ajoutez le code suivant au fichier de configuration Nginx :
server { listen 80; server_name www.example.com; location / { proxy_pass http://192.168.1.100:80; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }
La fonction de ce code est de proxy toutes les demandes d'accès à "www.example.com" vers l'IP de l'intranet. Parmi eux, le paramètre proxy_pass
spécifie l'adresse IP et le numéro de port dans l'intranet. Le paramètre proxy_set_header
est utilisé pour définir certaines informations d'en-tête afin de rendre le code plus précis lors du proxy. Pour des informations spécifiques, veuillez vous référer à la documentation officielle de Nginx. proxy_pass
参数指定了内网中的 IP 地址和端口号。proxy_set_header
参数用于设置一些头信息,让代码在进行代理时更加准确。具体信息可以参考 Nginx 官方文档。
在 Apache 上,我们可以使用 mod_proxy 模块来实现反向代理。首先,需要在 httpd.conf 中启用 mod_proxy 模块:
LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_http_module modules/mod_proxy_http.so
然后,在配置文件中添加以下代码:
<VirtualHost *:80> ServerName www.example.com ProxyRequests Off ProxyPass / http://192.168.1.100:80/ ProxyPassReverse / http://192.168.1.100:80/ ErrorLog logs/reverse-proxy-error.log CustomLog logs/reverse-proxy-access.log common </VirtualHost>
这段代码的作用是将所有对 "www.example.com" 的访问请求代理到内网中的 IP 上。其中,ProxyPass
指定了内网中的 IP 地址和端口号,ErrorLog
和 CustomLog
rrreee
Ensuite, ajoutez le code suivant dans le fichier de configuration : 🎜rrreee🎜La fonction de ce code est de proxy toutes les demandes d'accès à "www.example.com" sur l'IP dans le réseau. Parmi eux,ProxyPass
spécifie l'adresse IP et le numéro de port dans l'intranet, et ErrorLog
et CustomLog
sont utilisés pour définir les chemins des journaux d'erreurs et accéder aux journaux respectivement. Pour des informations spécifiques, veuillez vous référer à la documentation officielle d'Apache. 🎜🎜Pour résumer, pour résoudre le problème selon lequel PHP ne peut pas être ouvert sur le réseau externe et ne peut pas être ouvert sur le réseau interne, vous devez déployer un service proxy inverse sur le réseau externe. En configurant un proxy inverse, nous pouvons transmettre toutes les requêtes du réseau externe au réseau interne, réalisant ainsi la communication entre le réseau interne et le réseau externe. 🎜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!