超级全局变量
特点:预定义变量无需创建
作用:用于存储来自执行环境的特殊信息,如HTTP请求数据、服务器信息、会话数据
常见类别
-
$_GET
- 用于收集表单数据,当表单的
method
为get
时,数据会通过URL传递。例如,index.php?name=value
中的name
和value
可以通过$_GET['name']
访问。
- 用于收集表单数据,当表单的
-
$_POST
- 类似于
$_GET
,但用于收集表单数据,当表单的method
为post
时,数据会通过HTTP请求体传递。
- 类似于
-
$_REQUEST
- 包含了
$_GET
、$_POST
和$_COOKIE
的集合。它可以用于同时访问这三种类型的所有数据,但出于安全考虑,不建议在新代码中使用,因为它可能导致意料之外的数据访问。
- 包含了
-
$_SESSION
- 用于会话管理。会话是用户与服务器交互的一个阶段,服务器可以使用会话存储关于用户的信息。
-
$_COOKIE
- 包含了由客户端发送的cookie信息。
-
$_FILES
- 包含了通过表单上传的文件的信息。
实例
前端代码用于提交表单
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><form action="04.php" method="post" enctype="multipart/form-data"><!-- username -->用户名:<input type="text" name="username"><br><!-- 密码 -->密码:<input type="password" name="passwd"><br><!-- 上传文件 -->文件:<input type="file" name="file"><br><!-- 提交按钮 --><input type="submit" value="提交"></form>
</body>
</html>
form:表单标签,用于创建表单
表单属性
action:用于指定表单提交url
method:指定提交表单的方式
enctype:指定表单数据应该如何编码,multipart/form-data":文件上传使用的编码类型
表单控件
用户名输入框:
<input type="text" name="username">
:创建一个文本输入框,允许用户输入用户名。name
属性指定了数据在提交到服务器时的键名,即在服务器端可以通过$_POST['username']
来获取这个输入框的值。密码输入框:
<input type="password" name="passwd">
:创建一个密码输入框,用户输入的内容会被掩码处理,以防止旁人轻易看到。name
属性设置为passwd
,这样服务器可以通过$_POST['passwd']
获取密码。文件上传控件:
<input type="file" name="file">
:允许用户从本地文件系统中选择一个文件进行上传。name
属性指定了文件在表单数据中的键名,服务器端可以通过$_FILES['file']
来获取有关上传文件的信息。提交按钮:
<input type="submit" value="提交">
:创建一个提交按钮,当用户完成所有输入后,点击这个按钮会触发表单的提交。
表单提交过程
当用户填写完用户名、密码,选择好要上传的文件,并点击“提交”按钮后,
浏览器会将表单中的数据打包成一个multipart/form-data
格式的请求体,并发送一个POST请求到04.php
。
在服务器端的04.php
文件中,可以使用PHP的超级全局变量$_POST
来获取用户名和密码,使用$_FILES
来处理上传的文件。
使用超级全局变量获取表单提交内容
<?phpheader("content-type:text/html;charset=utf8");//查看用户通过post传参提交的表单数据var_dump($_POST);echo'<br>';//array(2) { ["username"]=> string(3) "123" ["passwd"]=> string(3) "123" }//提取上传表单中的单个数据var_dump($_POST['username']);echo "<br>";//request可同时接收get和post传参var_dump($_REQUEST);echo '<br> . <hr>';//查看表单上传文件var_dump($_FILES);/*array(1) { ["file"]=> array(5) { ["name"]=> string(7) "msf.png" ["type"]=> string(9) "image/png" ["tmp_name"]=> string(53) "C:\Users\Administrator\AppData\Local\Temp\php4ED5.tmp" ["error"]=> int(0) ["size"]=> int(48200) } }*/?>
查看表单提交内容
var_dump($_post);
array(2) { ["username"]=> string(3) "123" ["passwd"]=> string(3) "123" }
前端表单提交内容为关联数组形式,键为表单控件的name属性值,值为用户输入内容
提取上传表单中的单个数据
var_dump($_POST['username']);
通过name属性值为username的键值对,获取具体值
request可同时接收get和post传参
var_dump($_REQUEST);
不推荐使用存在安全隐患
查看表单上传文件
var_dump($_FILES);
数组内嵌套数组,
array(1) {
["file"]=> array(5) {
表单控件file的name属性值,用于区分多个控件
["name"]=> string(7) "msf.png"
文件名为msf.png
["type"]=> string(9) "image/png"
文件类型为(image/png)
["tmp_name"]=> string(53) "C:\Users\Administrator\AppData\Local\Temp\php4ED5.tmp"
文件地址
["error"]=> int(0)
文件上传错误次数
["size"]=> int(48200)
文件大小
}
}