ホームページ > バックエンド開発 > PHPチュートリアル > PHP スーパーグローバル変数の簡単な理解

PHP スーパーグローバル変数の簡単な理解

WBOY
リリース: 2023-04-11 09:42:01
転載
3922 人が閲覧しました

この記事では、PHP に関する関連知識を提供します。主にスーパー グローバル変数に関する関連内容を紹介します。スーパー グローバル変数は、組み込みおよび事前定義された特殊なタイプの変数です。どのスコープからでもアクセスできるため、必要はありません。特別なコード セグメントを実行するためのコードです。見てみましょう。皆さんのお役に立てれば幸いです。

PHP スーパーグローバル変数の簡単な理解

PHP スーパー グローバルについて理解する

スーパー グローバル変数は、任意のスコープからアクセスできるため、特別なタイプの変数です。特別なコードセグメントを実行せずに、任意のファイル、クラス、さらには関数からアクセスできます。

スーパーグローバル変数は組み込みで事前定義されています。プログラマは、PHP ライブラリを通じてこれらを使用できます。クラス ライブラリ内のすべての組み込みの事前定義変数がスーパーグローバル変数であるわけではないことに注意してください。

前提条件

この記事の内容を理解するには、読者が次の条件を満たしている必要があります。

  • PHP 変数宣言テクノロジの基本を理解します。
  • PHP について予備的な理解が必要です。

PHP スーパー グローバル変数の概要

スーパー グローバル変数は PHP 4.1.0 で導入され、それ以来 PHP の重要な部分となっています。 PHP には約 9 個のスーパーグローバル変数があり、自動グローバル変数と呼ばれることもあります。それらについては以下で説明します。

  • #$GLOBALS

  • $_SERVER

  • $_GET

  • ##$_POST
  • $_REQUEST
  • $_SESSION
  • $_COOKIE
  • $_FILE
  • $_ENV
  • これらのスーパー グローバル変数については、次のセクションで説明します。

#$グローバル

##GL OBALSPH P 変数。 #PHP 変数内の他のグローバルにアクセスするために使用されます。すべての PHPグローバル変数は、' # というファイルに保存されます。 ##GLOBALS は、PHP スクリプト内の他のグローバル変数にアクセスするために使用される PHP 変数です。すべての PHP グローバル変数は、「##G

   <!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 配列内にあるため、外部からアクセスできます。 $_SERVER$_SERVER は、PHP スクリプトの情報ヘッダー、パス、場所を保存するために使用されるスーパー グローバル変数です。変数には保存されるいくつかの要素があります。これらには、$_SERVER

$_SERVER['PHP_SELF'] が含まれます。これは、現在実行中のスクリプトのファイル名を返します。

$_SERVER['SERVER_NAME'] - Web サイトをホストしているサーバーの名前を返します。

$_SERVER['HTTP_HOST'] - 現在のリクエストのホスト ヘッダーを返します。

$_SERVER['SCRIPT_NAME'] - 現在のスクリプトへのパスを返します。

以下は、上記の要素の使用方法を示すサンプル コードです。
       <!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>
    ログイン後にコピー
  • 上記のコードの出力には以下が含まれます。

    • 一个文件名。
    • 主机服务器的名称。
    • 主机当前请求的标题。
    • 当前脚本的路径。

    $_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 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    php
    ソース:juejin.im
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    最新の問題
    人気のチュートリアル
    詳細>
    関連するチュートリアル
    人気のおすすめ
    最新のコース
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート