PHP基础知识之九个超全局变量

一、定义
PHP中内置了9个超全局变量,这些变量可以在全部作用域中使用,而他们有着不小的作用在这里做个总结。

二、预定义变量

1.请求类

  1. $_GET

超级全局变量包含使用GET方法传递的参数的有关信息时。
即通过url地址或表单get形式提交的请求,用$_GET获取请求信息,再做回应。

http://www.baidu.com?id=1
$_GET[‘id’] 的值为1

  1. $_POST

超级全局变量包含用POST方法传递的参数的有关信息。

<form action="action.php" method = "post">
    <p> Username : <br>
        <input type="text" name="username" size="20" maxlength="15" value="">
    </p>
    <p>
        <input type="submit" name="subscribe" value="subscribe!">
    </p>
</form>
在表单中添加qianke,在提交页面即可获得下边的值

         $_POST[ 'username' ] = " qianke " ;
  1. $_REQUEST

变量通过 GET,POST 和 COOKIE 输入机制传递给脚本文件,因此可以被远程用户篡改而并不可信。这个数组的项目及其顺序依赖于 PHP 的 variables_order 指令的配置.因此此超全局数组并不可信,不建议使用。

2.会话类

1.$_COOKIE

$_COOKIE超级全局变量存储了通过HTTP cookie传递到脚本的信息。这些cookie一般是由以前执行的PHP脚本通过PHP函数setcookie ( ) 设置的。

2.$_SESSION

$_SESSION 超级全局变量包含与所有会话有关的信息。注册会话信息能为你提供便利,这样就能在整个网站中引用这些会话信息,而无需通过GET或POST显示的传递数据。

    session_start();
  $_SESSION['XXX'] = xxx;
  当调用时同样要开启session

3.环境相关类
1.$GLOBALS

$GLOBALS 超级全局变量数组可以认为超级全局变量的超集,包含全局作用域内的所有变量。

2. ENV _ENV超级全局变量提供PHP解析所在服务器环境的有关信息。

$_ENV[‘HOSTNAME’] 服务器的主机名

$_ENV[‘SHELL’] 系统 shell

3.$_SERVER

超级全局变量包含由web服务器创建的信息,它提供了服务器和客户配置及当前请求环境的有关信息。

参数
PHP_SELF
当前执行脚本的文件名,与 document root 有关。例如,在地址为 http://example.com/test.php/foo.bar 的脚本中使用 $_SERVER[‘PHP_SELF’] 将得到 /test.php/foo.bar。FILE 常量包含当前(例如包含)文件的完整路径和文件名。

==SERVER_ADDR==
当前运行脚本所在的服务器的 IP 地址

‘SERVER_NAME’当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定。

‘SERVER_SOFTWARE’服务器标识字符串,在响应请求时的头信息中给出。

==SERVER_PROTOCOL==
请求页面时通信协议的名称和版本。例如,”HTTP/1.0”。

==REQUEST_METHOD==
访问页面使用的请求方法;例如,”GET”, “HEAD”,”POST”,”PUT”。

==REMOTE_ADDR==
浏览当前页面的用户的 IP 地址。

REMOTE_HOST浏览当前页面的用户的主机名。DNS 反向解析不依赖于用户的 REMOTE_ADDR。

‘REQUEST_TIME’请求开始时的时间戳。从 PHP 5.1.0 起可用。

‘REQUEST_TIME_FLOAT’请求开始时的时间戳,微秒级别的精准度。

‘QUERY_STRING’
query string(查询字符串),如果有的话,通过它进行页面访问。

==DOCUMENT_ROOT==
当前运行脚本所在的文档根目录。在服务器配置文件中定义。

‘HTTP_ACCEPT’当前请求头中 Accept: 项的内容,如果存在的话。

‘HTTP_ACCEPT_CHARSET’当前请求头中 Accept-Charset

4.文件
$_FILES
$_FILES超级全局变量包含通过POST方法向服务器上传的数据的有关信息。(上传文件)

$_FILES[‘upload-name’][‘name’]; 从客户端向服务器上传文件的文件名;

$_FILES[‘upload-name’][‘type’]; 上传文件的MIME类型,这个变量是否赋值取决于浏览器的功能。

$_FILES[‘upload-name’][‘size’]; 上传文件的大小(以字节为单位);

$_FILES[‘upload-name’][‘tmp_name’]; 上传之后,将此文件移到最终位置之前赋予的临时名。

$_FILES[‘upload-name’][‘error’]; 上传状态码。尽管这个变量的名为 error ,但实际上在成功的情况下也会填写这个变量。它有五个可能的值:

UPLOAD_ERR_OK 文件成功上传 0

UPLOAD_ERR_INI_SIZE 文件大小超出了 upload_max_filesize 指令所指定的最大值。

UPLOAD_ERR_FORM_SIZE 文件大小超出了MAX_FILE_SIZE隐藏表单域参数(可选)指定的最大值。

UPLOAD_ERR_PARTIAL 文件只上传了一部分

UPLOAD_ERR_NO_FILE 上传表单中没有指定文件

处理上传文件时,用move_upload_file()将文件移动到指定位置
move_uploaded_file ( string filename,string destination )

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值