백엔드 개발 PHP 문제 PHP에서 클라이언트 IP를 얻는 중 오류를 해결하는 방법

PHP에서 클라이언트 IP를 얻는 중 오류를 해결하는 방법

Apr 03, 2023 am 11:49 AM

PHP 프로그래밍 과정에서 클라이언트 IP를 얻는 것은 매우 일반적인 요구 사항입니다. 클라이언트 IP를 얻는 것은 간단한 문제가 아니며, 오류가 쉽게 발생할 수 있습니다. 오늘 우리는 일반적인 실수에 대해 논의할 것입니다.

오류 1: $_SERVER['REMOTE_ADDR'] 사용

초보자는 다음 공통 변수를 사용하여 클라이언트 IP 주소를 얻을 수 있습니다.

$ip = $_SERVER['REMOTE_ADDR'];
로그인 후 복사

이 방법은 실제로 클라이언트 IP를 얻을 수 있지만 클라이언트가 통과할 때 프록시로 액세스할 때 서버의 경우 이 변수는 클라이언트의 실제 IP가 아닌 프록시 서버의 IP 주소를 반환합니다.

실수 2: $_SERVER['REMOTE_ADDR'] 재사용

또 다른 실수는 $_SERVER['REMOTE_ADDR'] 변수를 재사용하는 것입니다. 즉, 변수를 여러 번 가져오는 것입니다. 이 메소드는 요청이 처리될 때 $_SERVER['REMOTE_ADDR']이 설정되기 때문에 일반적으로 동일한 IP를 반환합니다.

$ip = $_SERVER['REMOTE_ADDR'];
$ip2 = $_SERVER['REMOTE_ADDR'];
로그인 후 복사

오류 3: 잘못된 헤더 정보 가져오기

다음 주소를 방문하면 요청 헤더 정보를 볼 수 있습니다:

http://httpbin.org/headers

많은 튜토리얼에서 사람들은 HTTP_X_FORWARDED_FOR 또는 HTTP_CLIENT_IP를 사용하여 헤더 정보를 가져옵니다. 클라이언트 IP 주소. 그러나 서로 다른 프록시 서버가 전달을 위해 서로 다른 식별자를 사용할 수 있으므로 이 접근 방식은 최적이 아닙니다.

클라이언트 IP를 안정적으로 검색하려면 서버 구성 파일에 올바른 프록시 서버 IP 주소를 사용해야 합니다. 구체적인 방법은 아래 코드를 참조하세요.

if (!empty($_SERVER['HTTP_CLIENT_IP'])) {
    $ip = $_SERVER['HTTP_CLIENT_IP'];
} 
elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
    $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} 
else {
    $ip = $_SERVER['REMOTE_ADDR'];
}
로그인 후 복사

오류 4: 프록시 서버 뒤에서 프로토콜 오류 발생

프록시 서버 뒤에서 작업 중이고 PHP에서 HTTP 프로토콜이 http인지 https인지 감지하려는 경우 다음을 수행할 수 있습니다. 다음 코드를 사용하세요:

if (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) {
    $protocol = 'https://';
} 
else {
    $protocol = 'http://';
}
로그인 후 복사

오류 5: IIS 서버에서 IP 오류 가져오기

IIS 서버에서 작업하는 경우 $_SERVER['REMOTE_ADDR']를 사용하여 클라이언트 IP 주소를 가져올 때 다음 오류가 나타날 수 있습니다.

$_SERVER['REMOTE_ADDR'] returns 127.0.0.1 in IIS for local requests
로그인 후 복사

해결 이 문제를 해결하는 방법은 여러 가지가 있습니다. 한 가지 방법은 다음 코드를 사용하는 것입니다.

if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
    $ip = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
    $ip = array_shift($ip);
} 
else {
    $ip = $_SERVER['REMOTE_ADDR'];
}
로그인 후 복사

요약

클라이언트 IP 주소를 올바르게 가져오는 것은 골치 아픈 일이 될 수 있지만 민감한 데이터를 다룰 때는 문제가 됩니다. 중대한. 위의 오류는 일상적으로 발생할 수 있는 문제의 일부일 뿐이지만 올바른 방법을 익히고 서버 구성 파일을 사용하면 이러한 문제를 피할 수 있습니다.

위 내용은 PHP에서 클라이언트 IP를 얻는 중 오류를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 8 JIT (정시) 편집 : 성능 향상 방법. PHP 8 JIT (정시) 편집 : 성능 향상 방법. Mar 25, 2025 am 10:37 AM

PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. Mar 26, 2025 pm 04:13 PM

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

PHP 암호화 : 대칭 대 비대칭 암호화. PHP 암호화 : 대칭 대 비대칭 암호화. Mar 25, 2025 pm 03:12 PM

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

PHP 보안 파일 업로드 : 파일 관련 취약점 방지. PHP 보안 파일 업로드 : 파일 관련 취약점 방지. Mar 26, 2025 pm 04:18 PM

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

PHP 인증 & amp; 승인 : 보안 구현. PHP 인증 & amp; 승인 : 보안 구현. Mar 25, 2025 pm 03:06 PM

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

PHP CSRF 보호 : CSRF 공격 방지 방법. PHP CSRF 보호 : CSRF 공격 방지 방법. Mar 25, 2025 pm 03:05 PM

이 기사는 CSRF 토큰, 동일한 사이트 쿠키 및 적절한 세션 관리를 포함하여 PHP의 CSRF 공격을 방지하는 전략에 대해 설명합니다.

mysqli_query () 및 mysqli_fetch_assoc ()의 목적은 무엇입니까? mysqli_query () 및 mysqli_fetch_assoc ()의 목적은 무엇입니까? Mar 20, 2025 pm 04:55 PM

이 기사는 MySQL 데이터베이스 상호 작용에 대한 PHP의 MySQLI_Query () 및 MySQLI_Fetch_Assoc () 함수에 대해 설명합니다. 그것은 그들의 역할, 차이점을 설명하고 그들의 사용의 실질적인 예를 제공합니다. 주요 논쟁은 USIN의 이점에 중점을 둡니다

PHP를 사용하여 데이터베이스에서 데이터를 검색하는 방법은 무엇입니까? PHP를 사용하여 데이터베이스에서 데이터를 검색하는 방법은 무엇입니까? Mar 20, 2025 pm 04:57 PM

기사는 PHP, 커버 단계, 보안 측정, 최적화 기술 및 Solutions의 일반적인 오류를 사용하여 데이터베이스에서 데이터 검색에 대해 논의합니다. 문자 수 : 159

See all articles