PHP中的超全局变量,PHP初学者必须掌握的10个知识点

此间总计了PHP初读书人轻便认为纳闷的11个难题,供我们参照他事他说加以考察。

PHP中的超全局变量
从PHP 4.2.0 开始,register_globals 的暗中同意值为
off,那样一来,以前的居多足以直接行使的变量,如 $PHP_SELF
可能您设定的SESSION变量都不能够用
“$变量名”的款式拜见了,那可能会给您带来众多不改变,但却有支持安全性的增加。访谈这几个变量,你须要利用PHP
超全局变量,如下:
$_SERVER
变量由 Web 服务器设定只怕直接与近年来剧本的执市价况相关联。雷同于旧数组
$HTTP_SERVER_VARS
数组。以前的$PHP_SELF对应$_SERVER[‘PHP_SELF’],你能够运用phpinfo来查看你的$_SERVER变量。
$_GET
经由 HTTP GET 方法提交至脚本的变量。形似于旧数组 $HTTP_GET_VARS
数组。
$_POST
历经 HTTP POST 方法提交至脚本的变量。相通于旧数组 $HTTP_POST_VARS
数组。
$_COOKIE
行经 HTTP 库克ies 方法提交至脚本的变量。形似于旧数组 $HTTP_COOKIE_VARS
数组。
$_SESSION
近期登记给脚本会话的变量。雷同于旧数组 $HTTP_SESSION_VARS 数组。
$_FILES
途经 HTTP POST 文件上传而付出至脚本的变量。雷同于旧数组
$HTTP_POST_FILES 数组。
$_ENV

1、页面之间不或许传递变量

get,post,session在新式的php版本中活动全局变量是停业的,所以要从上一页面获得提交过来得变量要利用$_GET[‘foo’],$_POST[‘foo’],$_SESSION[‘foo’]来得到。当然也足以改过自动全局变量为开(php.ini改为register_globals
= OnState of Qatar;思索到包容性,如故勉强自身深谙新的写法比较好。

注:PHP中的超全局变量

从PHP 4.2.0 开始,register_globals 的默许值为
off,那样一来,早前的过多足以直接行使的变量,如 $PHP_SELF
也许你设定的SESSION变量都不能够用
“$变量名”的花样拜候了,那只怕会给你带给众多不改变,但却有扶持安全性的抓牢。访谈这么些变量,你需求使用PHP
超全局变量,如下:

$_SERVER

变量由 Web 服务器设定或许直接与当下剧本的实践情状相关联。相仿于旧数组
$HTTP_SERVER_VARS
数组。以前的$PHP_SELF对应$_SERVER[‘PHP_SELF’],你勉强可以phpinfo来查看你的$_SERVER变量。

$_GET

经过 HTTP GET 方法提交至脚本的变量。相仿于旧数组 $HTTP_GET_VARS 数组。

$_POST

行经 HTTP POST 方法提交至脚本的变量。雷同于旧数组 $HTTP_POST_VARS
数组。

$_COOKIE

经由 HTTP Cookies 方法提交至脚本的变量。相像于旧数组 $HTTP_COOKIE_VARS
数组。

$_SESSION

永利澳门游戏网站,现阶段注册给脚本会话的变量。相像于旧数组 $HTTP_SESSION_VARS 数组。

$_FILES

路过 HTTP POST 文件上传而付出至脚本的变量。形似于旧数组
$HTTP_POST_FILES 数组。

$_ENV

试行遭遇提交至脚本的变量。相同于旧数组 $HTTP_ENV_VARS 数组。

对于$_FILES变量:(文件域字段为“myfile”State of Qatar

$_FILES[‘myfile’][‘name’]

客商端机器文件的原名称(包涵路线卡塔尔(قطر‎。

$_FILES[‘myfile’][‘type’]

文本的 MIME 类型,供给浏览器提供该新闻的帮忙,比如“image/gif”。

$_FILES[‘myfile’][‘size’]

已上传文件的尺寸,单位为字节。

$_FILES[‘myfile’][‘tmp_name’]

文件被上传后在服务端储存的一时文件名(包含路线卡塔尔(قطر‎。

$_FILES[‘myfile’][‘error’]

和该公文上传相关的错误代码。[‘error’] 是在 PHP 4.2.0 版本中追加的。

当 php.ini 中的 register_globals 被安装为 on 时,$myfile_name 等价于
$_FILES[‘myfile’][‘name’],$myfile_type 等价于
$_FILES[‘myfile’][‘type’]等。

履市场价格况提交至脚本的变量。相通于旧数组 $HTTP_ENV_VARS 数组。

对于$_FILES变量:(文件域字段为“myfile”)
$_FILES[‘myfile’][‘name’]    
客户端机器文件的原名称(包蕴路线)。
$_FILES[‘myfile’][‘type’]    
文件的 MIME 类型,要求浏览器提供该音讯的支撑,比方“image/gif”。
$_FILES[‘myfile’][‘size’]    
已上传文件的高低,单位为字节。
 
$_FILES[‘myfile’][‘tmp_name’]    
文本被上传后在服务端储存的一时文件名(包含路线)。
$_FILES[‘myfile’][‘error’]    
和该文件上传相关的错误代码。[‘error’] 是在 PHP 4.2.0 版本中追加的。
 
当 php.ini 中的 register_globals 被安装为 on 时,$myfile_name 等价于
$_FILES[‘myfile’][‘name’],$myfile_type 等价于
$_FILES[‘myfile’][‘type’]等。

2、win32下的session必须要奇怪办事

php.ini默认的session.save_path = /tmp

那鲜明是linux下的配备,win32下php不恐怕读写session文件以致session无法接受,把它改成三个相对路线就可以了,举个例子session.save_path
= c:windowstemp。

3、展现错误音信

当php.ini的display_errors = On并且error_reporting =
E_ALL时,将展现全体的不当和唤醒,调节和测量试验的时候最棒展开以便纠错,如若你用从前php写法错误消息多半是有关未定义变量的。变量在赋值此前调用会有提示,消弭办法是探测或许屏蔽,举个例子突显$foo,能够if(isset($foo卡塔尔(قطر‎卡塔尔(قطر‎echo$foo 只怕echo @$foo

4、header already sent

本条怪诞平常会在你接受HEADE福睿斯的时候现身,他也许是两种原因:1,你在动用HEADE奇骏前P大切诺基ING只怕ECHO了2.你日前文件前边有空行3.您大概INCLUDE了四个文件,该文件尾巴部分有空行恐怕输出也会产出这种不当。

发表评论

电子邮件地址不会被公开。 必填项已用*标注