백엔드 개발 PHP 튜토리얼 PHP에서 슈퍼전역 변수를 사용하는 방법

PHP에서 슈퍼전역 변수를 사용하는 방법

May 20, 2023 pm 07:01 PM
가변 범위 초전역 변수 php hypertext preprocessor

PHP의 슈퍼 전역 변수는 전역 범위에서 액세스할 수 있는 변수를 의미합니다. 각 슈퍼 전역 변수는 $_GET, $_POST, $_COOKIE 등과 같이 PHP에서 미리 정의된 많은 변수를 포함하는 연관 배열입니다. 이러한 초전역 변수는 양식 데이터 가져오기, URL 매개변수 가져오기 등과 같은 사용자 요청에서 정보를 얻는 중요한 방법을 제공하기 때문에 웹 개발에서 매우 중요합니다.

이 글에서는 PHP에서 일반적으로 사용되는 슈퍼전역 변수의 역할, 사용 방법, 보안 문제 방지 방법을 자세히 소개합니다.

1. $_GET

$_GET은 URL을 통해 전달된 모든 매개변수를 포함하는 연관 배열입니다. 예를 들어 요청된 URL이 http://example.com/index.php?name=John&age=25인 경우 $_GET 배열에는 다음 요소가 포함됩니다.

array(
    'name' => 'John',
    'age' => '25'
);
로그인 후 복사

다음에서 이러한 값에 액세스할 수 있습니다. 방법:

echo $_GET['name']; // 输出 'John'
echo $_GET['age']; // 输出 '25'
로그인 후 복사

2. $_POST

$_POST는 POST 메서드를 통해 제출된 모든 양식 데이터를 포함하는 연관 배열이기도 합니다. 아래와 같이 이를 사용하여 양식에서 데이터를 가져올 수 있습니다.

<form action="process.php" method="post">
    <input type="text" name="name" />
    <input type="submit" value="Submit">
</form>
로그인 후 복사

양식을 제출할 때 $_POST 슈퍼 전역 변수를 사용하여 제출된 데이터를 가져올 수 있습니다.

echo $_POST['name'];
로그인 후 복사

3. $_COOKIE

$_COOKIE 현재 요청에서 전송된 모든 쿠키를 포함하는 연관 배열입니다. 대부분의 경우 $_COOKIE 변수를 사용하여 이전에 설정된 쿠키를 읽을 수 있습니다.

setcookie('name', 'John', time() + (86400 * 30), '/');
로그인 후 복사

이렇게 하면 사용자 브라우저에 "John"이라는 값을 가진 "name"이라는 쿠키가 설정되며 30일 후에 만료됩니다. 다음 코드를 사용하여 Cookie 값을 읽을 수 있습니다.

echo $_COOKIE['name'];
로그인 후 복사

4. $_SESSION

$_SESSION은 사용자 세션 중에 저장된 모든 변수를 포함하는 연관 배열입니다. 사용자가 귀하의 웹사이트를 방문할 때 $_SESSION이 한 사용자를 다른 사용자와 구별하는 유일한 요소입니다.

세션에 데이터를 저장하려면 다음 코드를 사용할 수 있습니다.

session_start();
$_SESSION['name'] = 'John';
로그인 후 복사

이 방법으로 세션 전체에서 특정 값의 상태를 유지할 수 있습니다.

session_start();
echo $_SESSION['name']; // 输出 'John'
로그인 후 복사

5. $_SERVER

$_SERVER는 An을 포함하는 현재 스크립트 실행에 대한 서버 및 클라이언트 관련 정보의 배열입니다. $_SERVER를 사용하면 다음과 같이 클라이언트가 요청한 일부 정보를 알 수 있습니다.

  • 원격 액세스 사용자의 IP 주소: $_SERVER['REMOTE_ADDR']
  • 사용자 에이전트: $_SERVER['HTTP_USER_AGENT']
  • 현재 스크립트 파일 경로: $_SERVER['SCRIPT_FILENAME']
  • 현재 요청 방법(GET/POST): $_SERVER['REQUEST_METHOD']
  • 현재 스크립트가 위치한 루트 디렉터리: $_SERVER['DOCUMENT_ROOT']

이것들은 이 정보는 개발자에게 매우 유용합니다.

6. $_FILES

$_FILES는 파일 업로드 시 파일 정보를 담고 있는 배열입니다. 파일을 업로드할 때 $_FILES를 사용하여 업로드된 파일을 조작할 수 있습니다.

다음 코드를 사용하여 $_FILES 값을 인쇄할 수 있습니다.

print_r($_FILES);
로그인 후 복사

이렇게 하면 파일 정보가 포함된 배열이 출력됩니다. 예:

Array
(
    [file] => Array
        (
            [name] => file.txt
            [type] => text/plain
            [tmp_name] => /tmp/phpzAduR5
            [error] => 0
            [size] => 123
        )

)
로그인 후 복사

7 보안 문제 방지

슈퍼글로벌 변수는 PHP에서 기본적으로 활성화됩니다. , 개발자는 이를 사용하여 웹 요청에서 데이터를 쉽게 얻을 수 있습니다. 그러나 보안 취약점의 원인이기도 합니다.

공격자는 웹 요청에 슈퍼전역 변수를 사용하여 악성 코드를 삽입하거나 웹 애플리케이션에 취약점을 생성할 수 있습니다. 따라서 개발자는 웹사이트를 보호하기 위해 다음 조치를 취해야 합니다.

  1. 입력 데이터를 필터링합니다. PHP 또는 정규식에서 filter_var() 함수를 사용하여 입력 데이터를 필터링하고 사용자가 악성 코드를 삽입하지 않도록 할 수 있습니다.
  2. 입력 데이터의 유효성을 검사합니다. 개발자는 모든 입력 데이터의 유효성을 검사하여 예상 형식과 길이를 준수하는지 확인해야 합니다. 예를 들어, 이메일 주소로 작업할 때 filter_var() 함수를 사용하여 이메일 주소가 올바른 형식인지 확인할 수 있습니다.
  3. 초전역 변수를 SQL 쿼리나 명령에 직접 전달하지 마세요. 이는 SQL 주입 및 기타 보안 문제를 방지하는 좋은 프로그래밍 방법입니다.
  4. 오류 보고 기능을 끄세요. 프로덕션 서버에서는 공격자가 애플리케이션 아키텍처 및 기타 민감한 정보에 대한 정보를 얻는 것을 방지하기 위해 PHP의 오류 보고 기능을 꺼야 합니다.

요약

PHP에서 슈퍼전역 변수를 사용하면 웹 요청에서 데이터를 쉽게 얻을 수 있습니다. 개발자는 이러한 변수를 주의 깊게 이해하고 웹 응용 프로그램을 만들 때 이를 사용해야 합니다. 그러나 개발자는 또한 슈퍼전역 변수의 보안 위험을 이해하고 애플리케이션 보안을 보장하기 위해 필요한 조치를 취해야 합니다.

위 내용은 PHP에서 슈퍼전역 변수를 사용하는 방법의 상세 내용입니다. 자세한 내용은 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP 함수의 변수 범위는 어떻게 결정되나요? PHP 함수의 변수 범위는 어떻게 결정되나요? Apr 16, 2024 pm 04:51 PM

PHP의 변수 범위는 로컬(함수 내), 전역(프로그램 내에서 액세스 가능), 클래스 범위(클래스 인스턴스 내에서 액세스 가능)로 구분됩니다. global 키워드는 지역 변수를 전역 변수로 선언할 수 있고, static 키워드는 지역 변수를 정적 변수로 선언하여 함수 호출 간에 해당 값을 유지할 수 있습니다.

Golang 함수 수명주기 및 변수 범위에 대한 심층적인 이해 Golang 함수 수명주기 및 변수 범위에 대한 심층적인 이해 Apr 19, 2024 am 11:42 AM

Go에서 함수 수명주기에는 정의, 로드, 연결, 초기화, 호출 및 반환이 포함됩니다. 변수 범위는 함수 수준과 블록 수준으로 구분됩니다. 함수 내의 변수는 내부적으로 표시되지만 블록 내의 변수는 블록 내에서만 표시됩니다. .

Go 언어의 변수 범위 및 수명주기 Go 언어의 변수 범위 및 수명주기 Jun 01, 2023 pm 12:31 PM

Go 언어는 오픈 소스 정적으로 유형화된 언어로 단순성, 효율성, 신뢰성이라는 특징을 갖고 있어 개발자들에게 점점 더 사랑받고 있습니다. Go 언어에서 변수는 프로그램의 가장 기본적인 데이터 저장 형태입니다. 변수의 범위와 수명 주기는 프로그램의 정확성과 효율성에 매우 중요합니다. 변수의 범위는 변수의 가시성과 접근성, 즉 변수에 액세스할 수 있는 위치를 나타냅니다. Go 언어에서는 변수의 범위가 전역 변수와 지역 변수로 구분됩니다. 전역 변수는 함수 외부에서 정의된 변수이며 전체 프로그램의 어느 곳에서나 사용할 수 있습니다.

Golang 함수에서 변수 범위를 정의하는 방법은 무엇입니까? Golang 함수에서 변수 범위를 정의하는 방법은 무엇입니까? Apr 11, 2024 pm 12:27 PM

Go에서 함수 범위는 변수가 선언된 함수로 변수 가시성을 제한합니다. 함수 내에서 변수 선언: varnametype=value 범위는 선언된 코드 블록으로 제한되며 다른 함수나 중첩 블록은 이러한 변수에 액세스할 수 없습니다.

PHP 5.6 변수 범위: static 키워드를 사용하여 정적 변수를 정의하는 방법 PHP 5.6 변수 범위: static 키워드를 사용하여 정적 변수를 정의하는 방법 Jul 30, 2023 pm 11:02 PM

PHP5.6 변수 범위: static 키워드를 사용하여 정적 변수를 정의하는 방법 PHP에서 변수 범위는 변수의 가시성과 액세스 범위를 결정합니다. 정적 변수는 함수 호출 간에 값을 변경하지 않고 유지하는 특수한 유형의 변수입니다. PHP5.6 이상에서는 static 키워드를 사용하여 함수 및 클래스 메서드 내에서 정적 변수를 정의할 수 있습니다. 정적 변수의 특징은 다음과 같습니다. 정적 변수의 범위는 선언된 함수나 메서드로 제한됩니다. 정적 변수는 함수 또는 메서드 호출 사이에 사용됩니다.

PHP에서 변수를 사용하는 방법 PHP에서 변수를 사용하는 방법 May 20, 2023 pm 02:33 PM

PHP는 개발자가 서버 측에서 동적 웹 애플리케이션을 만들 수 있게 해주는 매우 인기 있는 웹 개발 언어입니다. PHP에서 변수는 값과 데이터를 저장하는 데 사용되는 기본 데이터 구조입니다. 이 글에서는 PHP에서 변수를 사용하는 방법을 소개합니다. 변수의 기본 구문 PHP에서 변수를 선언하는 구문은 매우 간단합니다. 변수 이름은 달러 기호($)로 시작하고 그 뒤에 변수 이름이 옵니다. 변수 이름은 문자, 숫자, 밑줄을 조합하여 사용할 수 있지만 반드시 문자나 밑줄로 시작해야 합니다. 예를 들어 다음 코드는 이름을 선언합니다.

Python의 locals() 함수를 사용하여 현재 범위의 변수를 가져옵니다. Python의 locals() 함수를 사용하여 현재 범위의 변수를 가져옵니다. Aug 21, 2023 pm 09:52 PM

Python의 locals() 함수를 사용하여 현재 범위의 변수를 가져옵니다. Python에서 locals()는 현재 범위의 모든 변수를 가져오는 데 사용할 수 있는 내장 함수입니다. 이 함수는 현재 범위의 모든 변수 이름과 해당 값을 포함하는 사전을 반환합니다. 프로그래밍 프로세스 동안, 특히 디버깅 단계에서 현재 범위의 변수를 아는 것은 매우 유용하며, 이는 변수의 값과 상태를 보는 데 도움이 될 수 있습니다. locals() 함수는 바로 이 기능을 제공합니다. 아래에

Golang 함수의 변수 범위는 무엇입니까 Golang 함수의 변수 범위는 무엇입니까 Dec 22, 2023 pm 02:39 PM

Golang 함수의 변수 범위는 함수 내부 변수의 가시성과 수명주기를 나타냅니다. 변수는 함수 내 변수의 위치와 범위에 따라 지역변수, 매개변수 변수, 반환값 변수의 세 가지 유형으로 나눌 수 있습니다. 자세한 소개: 1. 지역 변수는 함수 내부에서 정의된 변수이며 함수 내에서만 사용할 수 있습니다. 해당 범위는 함수의 모든 코드 블록과 중첩된 코드 블록을 포함하여 함수 내부로 제한됩니다. 함수에서 받은 입력 매개변수는 함수 내부에서 사용할 수 있습니다. 해당 범위는 함수 내부 등으로 제한됩니다.

See all articles