【web 开发基础】PHP 中的预定义数组详解续集 (48)

举报
迷彩 发表于 2023/07/18 15:05:08 2023/07/18
【摘要】 前言在上一篇文章中,我们详细介绍了三个有关于预定义数组的用法,但是在实际的开发当中除了$_SERVER之外我们很少去使用其他两个,在实际的开发中我们经常用到的就是请求和会话参数的获取,比如我们在上一篇文章最后提到的$_GET和$_POST这两个,这两个就是我们平时实际开发中最常用来获取请求参数的预定于数组。当然还有$_REQUEST,$_REQUEST预定义数组同时包括了$GET和$_POS...

前言

在上一篇文章中,我们详细介绍了三个有关于预定义数组的用法,但是在实际的开发当中除了$_SERVER之外我们很少去使用其他两个,在实际的开发中我们经常用到的就是请求和会话参数的获取,比如我们在上一篇文章最后提到的$_GET和$_POST这两个,这两个就是我们平时实际开发中最常用来获取请求参数的预定于数组。当然还有$_REQUEST,$_REQUEST预定义数组同时包括了$GET和$_POST两种请求方式的参数,如果在开发时你无法确定客户端发送过来请求是get还是post,这时候可以$_REQUEST或许是不错的选择,这里只是举个例子,但是实际的开发中很少会出现无法判别请求方式的情况,就算前后端分离,一般从功能就能看出请求的方式。接下来我们就通过实际例子来详细了解请求和会话预定义数组的用法。


$_GET

在上一篇文章《【web 开发基础】PHP 中的预定义数组详解之一 (47)》中我们使用使用了$GLOBALS来获取URL的参数,$GLOBALS数组中几乎包含了所有的预定义变量,所以当你使用$GLOBALS获取URL相关的参数时,就需要使用$GLOBALS['GET'],多了一层,这时候我们使用获取URL参数专属的预定义数组$_GET就显得方便很多,特别是获取某个参数的值的时候,不需要写那么层,比如我们需要获取链接:http://127.0.0.1:81/demo1/?a=123123&b=456中参数a的值,我们直接使用$_GET['a']即可,下面我们通过实例来看看$_GET的使用:

经由URL请求提交至脚本的变量

$_GET超级全局变量包含使用GET方法传递的参数的有关信息。如果请求URL为http://www.example.com/index.html?name=张三&id=123, 就可以使用$_GET超级全局变量访问如下变量:

<?php
$_GET[ 'name' ] = "张三";
$_GET[ 'id' ] = 123;
?>

默认情况下,要访问通GET方法传递的变量,$_GET超级全局变量是唯一的途径,这也是我们日常开发中使用的获取方式。

 

$_POST

获取经由HTTP POST方法提交至脚本的变量

$_POST超级全局变量包含用POST方法传递的参数的有关信息。这是我们实际开发中涉及到添加和编辑功能提交表单数据到后端时,后端获取前端用户提交的数据常用到的方法,下面我们通过例子来体验它的用法:

<html>
<head>
</head>
<body>
<form action="index.php" method="post">
	<p>
	用户邮箱:<br>
	<input type="text" name="uname" size="20" maxlength="30" value="">
	</p>
	<p>
	密码:<br>
	<input type="password" name="pwd" size="20" maxlength="15" value="">
	</p>
	<p>
	<input type="submit" name="submit" value="提交">
	</p>
</form>
</body>
</html>


<?php
echo '<pre>';
print_r($_POST);
echo '<pre>';
?>

执行结果如下:



$_REQUEST

获取经由GET,POST和COOKIE机制提交至脚本的变量,因此该数组并不值得信任

$_REQUEST超级全局变量是一个全能选手,它记录了通过各种方法传递给脚本的变量,特别是GET ,POST 和 COOKIE 。当我们不确定前端传递参数的方式时,或者需要考虑兼容多种数据提交方式时我们会使用此方法。这些变量的顺序不依赖于它们在发送脚本中出现的顺序,而是依赖variables_order 配置指令所指定的顺序。建议少用这个超级变量,因为它不够安全。

<html>
<head>
</head>
<body>
<form action="index.php?name=张三" method="post">
	<p>
	用户邮箱:<br>
	<input type="text" name="uname" size="20" maxlength="30" value="">
	</p>
	<p>
	密码:<br>
	<input type="password" name="pwd" size="20" maxlength="15" value="">
	</p>
	<p>
	<input type="submit" name="submit" value="提交">
	</p>
</form>
</body>
</html>


<?php
echo '<pre>';
print_r($_REQUEST);
echo '<pre>';
?>

执行结果:从结果可以看出,$_REQUEST可以同时获取get和post两种方式传递的参数。

$_COOKIE

获取经由HTTP Cookies 方法提交至脚本的变量

$_COOKIE超级全局变量存储了通过HTTP cookie传递到脚本的信息。这些cookie一般是由以前执行的PHP脚本通过PHP函数setcookie ( ) 设置的。例如,假设使用 setcookie ( )存储了一个名为name、值为abc123的cookie。以后就可以通过调用$_COOKIE[ 'name' ]来获得这个值。

<?php
setcookie('name','abc123');
echo '<pre>';
print_r($_COOKIE);
echo '<pre>';
?>

第一刷新可能啥也没有,第二次刷新就会看到设置的cookie,还可以设置cookie的过期时间。cookie实际的开发中常用于记住登录信息的功能

执行结果如下:


$_SESSION

获取当前注册给脚本会话的变量

$_SESSION 超级全局变量包含与所有会话有关的信息。注册会话信息能为你提供便利,这样就能在整个网站中引用这些会话信息,而无需通过GET或POST显示的传递数据。特别是我们最常见的登录功能,http本身是无状态,这样服务器就无法知道第一次和第二次请求是否来自同一个用户,这时候session就派上用场了,这时候我们可以在用户登录信息验证成功后使用$_SESSION记录用户登录信息,后续我们可以通过这些信息来确认用户的登录状态

<?php
$_SESSION['name'] = 'zhangsan';//设置session

//获取session
echo $_SESSION['name'];
?>


$_FILES

获取经由HTTP POST文件上传而提交至脚本的变量。$_FILES超级全局变量包含通过POST方法向服务器上传的数据的有关信息。这个超级全局变量与其他的变量有所不同,它是一个二维数组,包含5个元素。第一个下标标示表单的文件上传元素名;第二个下标是五个预定义下标之一,这些下标描述了上传文件的某个属性:

<?php
$_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 文件成功上传
UPLOAD_ERR_INI_SIZE 文件大小超出了 upload_max_filesize 指令所指定的最大值。
UPLOAD_ERR_FORM_SIZE 文件大小超出了MAX_FILE_SIZE 隐藏表单域参数(可选)指定的最大值。
UPLOAD_ERR_PARTIAL 文件只上传了一部分
UPLOAD_ERR_NO_FILE 上传表单中没有指定文件
*/
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。