PHP03

PHP03

1、提交地址:

action。用户点击提交后,发送请求的地址。一般为了便于维护,最常见的是提交给当前文件,然后在当前文件判断是否为表单提交请求,表单的处理逻辑放在Html之前,为了避免写死提交地址而导致的代码修改,鲁棒性不强,使用SERVER超全局变量。

PHP03

鲁棒性:指我们的程序应对变化的能力

PHP03

2、提交方式:

PHP03

get和post的方式差异:

请求方式不同

传参方式不同:

get——url传参

post——请求体传参

3、表单元素对的提交

所有表单的提交都必须有name属性

button:

默认value为on。表单中使用了radio,一定要为相同的raadio设置不同的value,让服务端可以辨别

checkbox:

如果没有选中则不会提交,选中提交后value值为on

也可以设置value。

同时提交多个选中项:

在name属性后加[]

下拉框:

默认提交的是option标签中的内容(innertext)

也可以设置value

4、案例:编写功能完整的用户注册页面

1)表单处理三部曲:

接收并校验、持久化、响应

2)表单状态保持:

include和require函数其实可以有返回值,可返回一个含配置代码的数组

return Array(

‘SYSTEM_NAME’=> ‘cc’

);

然后在引入时

PHP03

5、文件域的基本使用

1)

如果表单内含有文件域,则提交方式必须为post

enctype必须为multipart-from-data,系统默认为urlencoded,是键值对的形式。

接收用户上传的文件时,用一个叫做$_FILES的超全局成员

2)文件上传服务端处理逻辑

判断服务端有没有收到上传的文件-判断文件上传是否发生错误-将文件从临时目录移动到网站范围内–判断指定目标目录是否存在-判断是否移动成功

<?php
function upload(){ if (!isset($_FILES['avatar'])){
$GLOBALS['message'] ='未上传';
return;
}
$avatar = $_FILES['avatar'];
if($avatar['error']!==UPLOAD_ERR_OK){
$GLOBALS['message'] ='上传失败';
return;
}
$source=$avatar['tmp_name'];
$target='./uploads/'.$avatar['name'];
$moved=move_uploaded_file($source, $target);
if(!$moved){
$GLOBALS['message'] ='上传失败';
return;
}
echo '上传成功';
}
if($_SERVER['REQUEST_METHOD']==='POST'){
upload();
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<form method="post" enctype="multipart/form-data" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<input type="file" name="avatar"> <button>上传</button>
<?php if(isset($message)):?>
<p style="red">
<?php echo $message; ?>
</p>
<?php endif ?> </form>
</body>
</html>

3)上传大文件的问题

PHP03

修改请求报文限制大小post_max_size

修改上传的文件限制大小upload_max_filesize

上一篇:IOS 沙盒机制 && 关于document\library\tmp的灵活使用


下一篇:TMF大数据分析指南 Unleashing Business Value in Big Data(二)