이 글은 기계 번역의 미러 문서이며, 원본 기사로 바로 이동하려면 여기를 클릭해 주세요.

보기: 15623|회답: 0

[웹] 프론트엔드의 Nginx와 백엔드의 Apache가 사용자의 실제 IP 주소를 얻습니다

[링크 복사]
게시됨 2014. 11. 3. 오전 9:46:05 | | |
최근에는 전반적으로아파치-2.2 그리고아파치-2.4LNMP 원클릭 설치 패키지",은긴스프론트엔드로서 Apache는 Nginx 프론트엔드의 IP 주소(127.0.0.1)만 얻을 수 있으며, 사용자의 실제 IP 주소는 얻을 수 없습니다.
Nginx는 다음과 같이 구성되어 있습니다:
  1. location / {
  2.         try_files $uri @apache;
  3.         }

  4. location @apache {
  5.         internal;
  6.         proxy_pass http://127.0.0.1:8080;
  7.         include proxy.conf;
  8.         }

  9. location ~ .*\.(php|php5)?$  {
  10.         proxy_pass http://127.0.0.1:8080;
  11.         include proxy.conf;
  12.         }
코드 복사
  1. proxy_connect_timeout 300s;
  2. proxy_send_timeout 900;
  3. proxy_read_timeout 900;
  4. proxy_buffer_size 32k;
  5. proxy_buffers 4 64k;
  6. proxy_busy_buffers_size 128k;
  7. proxy_redirect off;
  8. proxy_hide_header Vary;
  9. proxy_set_header Accept-Encoding '';
  10. proxy_set_header Referer $http_referer;
  11. proxy_set_header Cookie $http_cookie;
  12. proxy_set_header Host $host;
  13. proxy_set_header X-Real-IP $remote_addr;
  14. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
코드 복사
Apache에서 실제 IP 주소를 얻기 위한 두 가지 모듈이 있습니다:
mod_rpaf: Apache-2.2는 지원되지 않습니다; Apache-2.4는 지원되지 않습니다. 온라인에 많은 튜토리얼이 있습니다
mod_remoteip: Apache-2.4는 모듈을 포함하며; Apache-2.2 지원;추천
Apache-2.2.25
mod_rpaf 모듈
  1. wget http://stderr.net/apache/rpaf/download/mod_rpaf-0.6.tar.gz
  2. tar -xzvf mod_rpaf-0.6.tar.gz
  3. cd mod_rpaf-0.6/
  4. /usr/local/apache/bin/apxs  -i -c -n mod_rpaf-2.0.slo mod_rpaf-2.0.c
코드 복사
Apache 구성 추가
  1. vi  /usr/local/apache/conf/httpd.conf
  2. Include conf/extra/httpd-rpaf.conf
  3. vi /usr/local/apache/conf/extra/httpd-rpaf.conf

  4. LoadModule rpaf_module        modules/mod_rpaf-2.0.so
  5. RPAFenable On
  6. RPAFsethostname On
  7. RPAFproxy_ips 127.0.0.1 10.8.0.110 # 代理服务器的ip地址(记得做相应修改)
  8. RPAFheader X-Forwarded-For
코드 복사
참고: RPAFproxy_ips 후에 프록시 서버의 IP 주소를 추가하고, 몇 가지를 입력하세요
테스트
  1. # /usr/local/apache/bin/apachectl -t
  2. # /usr/local/apache/bin/apachectl restart
  3. # 看日志
코드 복사
mod_remoteip
Apache-2.2 하에서 mod_remoteip 구성은 다음과 같습니다:
설치
  1. wget https://github.com/ttkzw/mod_remoteip-httpd22/raw/master/mod_remoteip.c
  2. /usr/local/apache/bin/apxs -i -c -n mod_remoteip.so mod_remoteip.c
코드 복사
프로필 수정:
  1. vi /usr/local/apache/conf/httpd.conf
  2. Include conf/extra/httpd-remoteip.conf
  3. vi /usr/local/apache/conf/extra/httpd-remoteip.conf
  4. LoadModule remoteip_module modules/mod_remoteip.so
  5. RemoteIPHeader X-Forwarded-For
  6. RemoteIPInternalProxy 127.0.0.1
코드 복사
테스트:
  1. # /usr/local/apache/bin/apachectl -t
  2. # /usr/local/apache/bin/apachectl restart
  3. # 看日志
코드 복사
Apache-2.4 구성mod_remoteip 위 내용 외에도(자체 mod_remoteip 있는 모듈을 설치할 필요가 없음) 로그 형식도 수정해야 합니다(오랫동안 토스해야 합니다).
  1. LogFormat "%h %a %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined
  2. LogFormat "%h %a %l %u %t "%r" %>s %b" common
  3. LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i" %I %O" combinedi
코드 복사

로그 형식에 %a를 추가하세요





이전의:두니앙이 아직도 이렇게 연주할 수 있다고 들었어! 너 흔들었어! 흔들어!
다음:nginx 프록시 모드: 클라이언트의 실제 IP 주소를 얻습니다
면책 조항:
Code Farmer Network에서 발행하는 모든 소프트웨어, 프로그래밍 자료 또는 기사는 학습 및 연구 목적으로만 사용됩니다; 위 내용은 상업적 또는 불법적인 목적으로 사용되지 않으며, 그렇지 않으면 모든 책임이 사용자에게 부담됩니다. 이 사이트의 정보는 인터넷에서 가져온 것이며, 저작권 분쟁은 이 사이트와는 관련이 없습니다. 위 내용은 다운로드 후 24시간 이내에 컴퓨터에서 완전히 삭제해야 합니다. 프로그램이 마음에 드신다면, 진짜 소프트웨어를 지원하고, 등록을 구매하며, 더 나은 진짜 서비스를 받아주세요. 침해가 있을 경우 이메일로 연락해 주시기 바랍니다.

Mail To:help@itsvse.com