> 백엔드 개발 > PHP 튜토리얼 > PHP 슈퍼 전역 변수에 대한 간단한 이해

PHP 슈퍼 전역 변수에 대한 간단한 이해

WBOY
풀어 주다: 2023-04-11 09:42:01
앞으로
3894명이 탐색했습니다.

이 글은 PHP에 대한 관련 지식을 제공하며, 주로 슈퍼 전역 변수에 대한 관련 내용을 소개합니다. 슈퍼 전역 변수는 내장되고 사전 정의된 특별한 유형의 변수이며 범위 내에서 필요하지 않은 모든 액세스에서 선택할 수 있습니다. 특별한 코드 세그먼트의 실행을 살펴보겠습니다. 이것이 모든 사람에게 도움이 되기를 바랍니다.

PHP 슈퍼 전역 변수에 대한 간단한 이해

PHP 슈퍼 전역 이해하기

슈퍼 전역 변수는 모든 범위에서 액세스할 수 있는 특별한 유형의 변수입니다. 특별한 코드 세그먼트를 실행하지 않고도 모든 파일, 클래스 또는 함수에서 액세스할 수 있습니다.

수퍼글로벌 변수는 내장되어 있으며 사전 정의되어 있습니다. 프로그래머는 PHP 라이브러리를 통해 이를 사용할 수 있습니다. 클래스 라이브러리에 내장된 사전 정의된 변수가 모두 슈퍼전역 변수는 아닙니다.

사전 조건

이 기사의 내용을 이해하려면 독자는 다음 조건을 갖추어야 합니다.

  • PHP 변수 선언 기술에 대한 기본적인 이해가 있어야 합니다.
  • PHP에 대한 사전 이해가 필요합니다.

PHP 슈퍼 전역 변수 소개

슈퍼 전역 변수는 PHP 4.1.0에서 도입되었으며 그 이후로 PHP의 중요한 부분이 되었습니다. PHP에는 automatic globals 라고 불리는 약 9개의 슈퍼전역 변수가 있습니다. 아래에 설명되어 있습니다.

  • $GLOBALS

  • $_SERVER

  • $_GET

  • $_POST

  • $_REQUEST

  • $_SE

  • $_COOKIE

  • $_FILE

  • $_ENV

다음 섹션에서 이러한 슈퍼 전역 변수에 대해 논의하겠습니다.

$GLOBALS

GLOBASPHP변수, PHP 스크립트에서 다른 전역 변수에 액세스하는 데 사용됩니다. 모든 PHP 전역 변수는 'GLOBALS라는 파일에 저장되며, PHP 스크립트에서 다른 전역 변수에 액세스하는 데 사용되는 PHP 변수입니다. 모든 PHP 전역 변수는 `

   <!doctype html>
   <html>
   <head>
   <title>GLOBAL example</title>
     </head>
     <body>
     <?php
        //php Script
       // Varriable declaration
       $a = 5;
       $b = 6;
         function multiplication(){
          $GLOBALS[&#39;c&#39;] = $GLOBALS[&#39;a&#39;]* $GLOBALS[&#39;b&#39;];
         }

         multiplication();
         echo $c;

      ?>
    </body>
   </html>
로그인 후 복사
위 예에서 변수 $c는 내부와 외부에서 모두 접근 가능합니다. 함수는 $GLOBALS 배열에 있기 때문입니다.

的数组中。index 中保存着variable name` 。

下面是一个使用超全局变量$GLOBAL 的例子:)

   <!doctype html>
   <html>
   <head>
   <title> $_SERVER example</title>
   </head>
       <body>
       <?php
       // PHP script
              echo $_SERVER[&#39;PHP_SELF&#39;];
              echo "<br>";
              echo $_SERVER['SERVER_NAME'];
              echo "<br>";
              echo $_SERVER['HTTP_HOST'];
              echo "<br>";
              echo $_SERVER['SCRIPT_NAME'];
        ?>
       </body>
   </html>
로그인 후 복사

在上面的例子中,变量$c 在函数内部和外部都可以访问,因为它在$GLOBALS 数组中。

$_SERVER

$_SERVER 是一个超全局变量,用于保存PHP脚本的信息头、路径和位置。 变量有几个元素被保存。它们包括$_SERVER$_SERVER

  • $_SERVER는 PHP 스크립트의 정보 헤더, 경로 및 위치를 저장하는 데 사용되는 슈퍼 전역 변수입니다. 변수에는 저장되는 여러 요소가 있습니다. 여기에는 현재 실행 중인 스크립트의 파일 이름을 반환하는 $_SERVER

  • $_SERVER['PHP_SELF']가 포함됩니다.

  • $_SERVER['SERVER_NAME'] - 웹사이트를 호스팅하는 서버의 이름을 반환합니다.

  • $_SERVER['HTTP_HOST'] - 현재 요청의 호스트 헤더를 반환합니다.

$_SERVER['SCRIPT_NAME'] - 현재 스크립트의 경로를 반환합니다.

아래는 위의 요소를 사용하는 방법을 보여주는 샘플 코드입니다. 🎜
   <!doctype html>
   <html>
   <head>
   <title>$_GET example</title>

   </head>
      <body>
         <!-- html form -->
      <form action="" method="GET">
          <label>Name</label>
          <input type="text" name="Name">
          <label>Email</label>
          <input type="text" name="Email">
          <button>Submit</button>

      </form>

          </body>
   </html>
로그인 후 복사
로그인 후 복사
🎜위 코드의 출력에는 다음이 포함됩니다. 🎜
  • 一个文件名。
  • 主机服务器的名称。
  • 主机当前请求的标题。
  • 当前脚本的路径。

$_GET

$_GET 变量是一个PHP超全局变量,用于收集HTML表单提交后的数据。HTML表单的结构是这样的:$_GET 作为一个方法。$_GET 也可以用来检索在uniform resource locator 中发送的数据。

下面是一个例子,说明如何在HTML表单中实现$_GET 变量。

   <!doctype html>
   <html>
   <head>
   <title>$_GET example</title>

   </head>
      <body>
         <!-- html form -->
      <form action="" method="GET">
          <label>Name</label>
          <input type="text" name="Name">
          <label>Email</label>
          <input type="text" name="Email">
          <button>Submit</button>

      </form>

          </body>
   </html>
로그인 후 복사
로그인 후 복사

当用户点击Submit 按钮时,表单中的信息会用GET 方法发送,并显示在URL 。然而,每次最多只能发送2048 字符。

$_POST

就像$_GET 变量一样,$_POST 收集来自HTML表单的值。使用这种方法发送的信息不会显示在URL中。一次可以发送的字符数也没有限制。

下面是一个例子。

    <!doctype html>
    <html>
    <head>
    <title>$_POST example</title>

    </head>
      <body>
          <!-- html form -->
      <form action="" method="POST">
         <label>Name</label>
         <input type="text" name="Name">
         <label>Email</label>
         <input type="text" name="Email">
         <button>Submit</button>
      </form>

      </body>
     </html>
로그인 후 복사

为什么POST变量优于GET?

尽管POSTGET 方法实现了相同的功能,但由于以下原因,POST 更受青睐。

  • POST方法对可以发送的数据大小没有限制。

  • POST方法可以同时发送ASCII和二进制数据。

  • POST方法不会在URL上显示正在发送的信息,因此可以防止建立书签。

  • POST方法使用一个HTTP header 来发送数据。这促进了数据安全。

$_REQUEST

$_REQUEST 变量是一个PHP超全局,用于在提交表单后收集数据。它包含了$_GET$_POST ,甚至默认的$_COOKIE 的内容。各个字段的数据可以由PHP使用$_REQUEST 变量来收集。

下面的例子显示了如何使用$_REQUEST 这个变量。

<!doctype html>
<html>
    <head>
    <title>$_REQUEST example</title>
    </head>
     <body>
     <form action="<?php echo $_SERVER[&#39;PHP_SELF&#39;];?>" method="POST">

        <label>Name</label>
        <input type="text" myname="Name">
        <button>Submit</button>

      </form>

      <?php
          if($_SERVER["REQUEST_METHOD"]=="POST"){
             $name = $_REQUEST[&#39;myname&#39;];
             if(!empty($myname))
          {
        
            echo $myname;

          }else{
             echo "Empty name";
          }

         }
      ?>

    </body>
</html>
로그인 후 복사

上述代码的输出将是表单中已提交的name 。如果没有提交名字,它将打印一个信息Empty name

$_SESSION

$_SESSION 变量是一个PHP的超级全局,它可以在用户每次打开网站时存储和利用有关网站用户的信息,直到网站关闭。

每次用户访问网站时,都会启动一个会话。下面的函数被用来在PHP代码中启动一个会话。

   session_start()
로그인 후 복사

会话开始后,需要使用$_SESSION 变量进行设置。

当用户离开一个网站时,会话被自动销毁。这是在用户不知情的情况下使用下面的PHP函数完成的。

session_destroy()
로그인 후 복사

下面的例子演示了$_SESSION 的使用。

<? php
    session_start();
?>

 <!doctype html>
 <html>
   <head>
      <title>$_SESSION demonstration code</title>
   </head>

 <body>
      <?php
         //Set session varriables

         $_SESSION["name"]="Mackrine";
         $_SESSION["favcolor"]="Blue";
         echo "session varriables are set";
      ?>
 </body>

</html>
로그인 후 복사

$_COOKIE

Cookie是一个小文件,由服务器存储在用户的计算机中。它可以识别用户。每当向服务器发出请求时。通常会在请求的同时发送一个cookie。PHP 使用setcookie() 函数创建 cookie。

   setcookie(cookie_name,cookie_value, expiry, path, domain,secure,httponly)
로그인 후 복사

该语法有许多参数。然而,只有name 参数是必需的。

在创建之后,可以使用超全局$_COOKIE 变量来检索cookie。下面的代码显示了如何创建和检索一个cookie。

  <?php

    $cookie_name = "uname";
    $cookie_value = "Mackrine";

   //setting cookie

    setcookie($cookie_name, $cookie_value, time()+(86400*30),"/");

     ?>
    <!doctype html>
    <html>
    <body>
    <?php

       if(isset($_COOKIE[$cookie_name]))
        {
            echo "Cookie name:" .$cookie_name;
            echo "<br>";
            echo "Cookie value:" .$cookie_value;

        }
         else
         {
            echo $cookie_name. " is not set!";

         }
    ?>
    </body>
    </html>
로그인 후 복사

只有在过期的情况下,才可以使用setcookie() 函数删除cookie。

$_FILES

$_FILES 是一个变量,包含使用HTTPPOST方法上传的项目。 数组包含几个元素,如下所述。$_FILES

  • $_FILES['file']['name'] - 这通常是要上传的文件的原始名称。

  • $_FILES['file']['type'] - 这是指被上传文件的类型。

  • $_FILES['file']['size'] - 以字节为单位的文件大小。

  • $_FILES['file']['tmp_name'] - 它指的是在服务器上上传的存储文件的临时文件名。

  • $_FILE['file']['error']- 文件上传的相关错误代码。

总结

超全局变量是PHP语言的核心。在PHP编程中需要这些变量来制作高功能的程序。因此,你可以利用这些信息来制作高质量的应用程序。

推荐学习:《PHP视频教程

위 내용은 PHP 슈퍼 전역 변수에 대한 간단한 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
php
원천:juejin.im
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿