(1)file_uploads = On / off (是否可以接受文件上传)
(2)max_input_time = 60 在提示错误之前解析输入所花费的最长时间,以秒为单位,如果经常需要传输大文件,这个时限应该设置得合理一些。
(3)max_file_uploads = 20 对可以同时上传文件数设置了一个上限。
(4)memory_limit = 128M 设置脚本可以分配得最大内存,可以防止脚本独占服务器内容,甚至导致服务器崩溃。
(5)post_max_size = 8M 对通过post 方法提交得数据大小设置了一个限制
(6)upload_max_filesize = 2M 限定上传文件的最大大小,以MB为单位,该值必须小于post_max_size(通过这条语句可以改变上传文件的最大大小)
(7)upload_temp_dir = "...../..../..../..."文件上传得临时目录。
(1)$_FILES["控件的名字(即name)"]["name"] :上传的文件名(name就是文件名的信息,含扩展名)
(2)$_FILES["控件的名字(即name)"]["type"] :文件类型,上传文件的类型,这个值有时会产生意外结果,建议通过文件扩展名显式验证
(3)$_FILES["控件的名字(即name)"]["tmpname"]:临时文件夹中的文件名,如果需要上传文件,就需要把临时文件给移动到指定文件上,否则,程序执行完后,临时文件就会被清空。
(4)$_FILES["控件的名字(即name)"]["size"] 上传文件的大小,以字节为单位
(5)$_FILES["控件的名字(即name)"]["error"] 上传结果
1、UPLOAD_ERR_OK: 上传成功,则返回 0
2、UPLOAD_ERR_INI_SIZE:超出文件规定大小(upload_max_filesize) ,则返回1
3、UPLOAD_ERR_FORM_SIZE 超出嵌入在HTML表单中的文件max_file_size 大小,其中max_file_size可能会被黑客修改,所以不建议使用。此时返回 2
4、UPLOAD_ERR_PARTIAL 文件没有完全上传,一般在发生网络错误时会出现,则返回 3
5、UPLOAD_ERR_NO_FILE 用户没有指定上传文件就提交表单,则返回 4
6、5 是文件传上去了,但是转译没有成功。
7、UPLOAD_ERR_NO_TMP_DIR 临时目录不存在,则返回 6
8、UPLOAD_ERR_CANT_WRITE 如果文件无法写入磁盘,则返回7
9、UPLOAD_ERR_EXTENSION 如果PHP的配置问题导致上传失败,则返回8
、
注意:可以通过 print_r 来查看系统数组$_FILE的内容
如:
html代码:
php代码:
echo "";
print_r($_FILES);
运行结果:
Array
(
[my] => Array
(
[name] => 新建 Microsoft Word 文档.docx //上传文件的文件名
[type] => application/vnd.openxmlformats-officedocument.wordprocessingml.document //文件的类型
[tmp_name] => C:\wamp\tmp\phpC374.tmp // 文件临时的储存地址
[error] => 0 //文件上传过程中有没有问题
[size] => 0 //上传文件的大小,以字节为单位
)
)
(1)判断文件是否已上传(is_uploaded_file()):
is_uploaded_file()函数是函数判断指定的文件是否是通过 HTTP POST 上传的。
如果 filename 所给出的文件是通过 HTTP POST 上传的则返回 TRUE。这可以用来确保恶意的用户无法欺骗脚本去访问本不能访问的文件,例如 /etc/passwd。
注意:is_uploaded_file($_FILES['file']['tmp_name'])函数要在move_uploaded_file()函数之前使用,要先判断是不是正确合法的文件来源,然后再进行上传。
(2)移动已上传文件(move_uploaded_file):
move_uploaded_file 函数 ,自动检查文件确实是通过HTTP POST机制上传的,如果指定的文件未上传,则移动失败,返回false。在使用该函数时可以不必使用is_uploaded_file()进行判断。
md5 ( $_POST[ ‘ 密码控件(input)中的name ’ ] );
输出时会输出,32位的整数。
html代码:
密码
php代码:
echo md5 ( $_POST[ 'password' ] );
如果需要使用表单以文件的形式上传,则 from 标签里面必须包含三个属性:
如果不存在,使用mkdir("文件名");创建一个新的文件夹。
如:
html代码:
php代码:
$dir = 'upload'; // 将文件名赋给变量 $dir
if(!is_dir($dir)) //判断文件是否存在,存在返回 1
{
mkdir($dir); //如果不存在,创建一个新的文件夹
}
move_uploaded_file( $_FILES[ ' 控件中的name ' ][ ' temp_name '(临时存储路径) ],‘ upload/ ’ (移动到指定文件夹下面) . (将提交上来的文件名(可以修改)和指定文件夹名进行字符串连接) $ _FILES[ ' 控件中的name ' ][ ' name '] ) 也可以用来判断(使用 if 语句)临时文件是否移动成功,成功返回 1 否则,返回 0 。
如:
html:
php:
$dir = 'upload';
if(!is_dir($dir))
{
mkdir($dir);
}
move_uploaded_file($_FILES['my']['tmp_name'],'upload/'.$_FILES['my']['name']);
使用 is_uploaded_file ( $_FILES[ ' 控件中的name ' ][ ' tmp_name ' ] )判断临时文件上传成功了没有,成功返回 1 否则,返回 0 。
如:
html:
php:
if(is_uploaded_file($_FILES['my']['tmp_name'])) //判断指定的文件是否是通过 POST 成功上传的
{
if(move_uploaded_file($_FILES['my']['tmp_name'],'upload/'.$_FILES['my']['name']))
//判断文件移动是否成功
{
echo "";
}else{
echo "";
}
}
此时 html 中的文件提交直接提交到当前页面即可。
如:
无标题 1
注册页面
";
$dir = 'upload';
if(!is_dir($dir))
{
mkdir($dir);
}
if(is_uploaded_file($_FILES['my']['tmp_name']))// 判断指定的文件是否是通过 POST 成功上传的
{
if(move_uploaded_file($_FILES['my']['tmp_name'],'upload/'.$_FILES['my']['name']))
{
echo "";
}else{
echo "";
}
}
echo "
";
?>
我们可以判断:有没有点击提交按钮,如果点击了,就执行 php 代码,没点击就不需要执行 php 代码。
判断有没有点击提交按钮的时候,需要通过控件(input)里面的 name 属性找到这个控件。
使用$_POST[' 控件里面的name '] 来接收是否点击提交。
错误屏蔽运算符:@
如:
无标题 1
注册页面
";
if(@$_POST['submit'])//接收上传按钮的信息,如果点击上传按钮则为真,就执行代码
//@:错误屏蔽符,屏蔽错误提示,当没点击上传按钮时,会提示错误。
{
$dir = 'upload';
if(!is_dir($dir))
{
mkdir($dir);
}
if(is_uploaded_file($_FILES['my']['tmp_name']))
{
if(move_uploaded_file($_FILES['my']['tmp_name'],'upload/'.$_FILES['my']['name']))
{
echo "";
}else{
echo "";
}
}
echo "
";
}
?>
使用:empty()函数:
如:
if(!empty( $_FILES[ ' my ' ][ ' name ' ] )){
}
或:
if( $_FILES[ ' my ' ][ ' name ' ] !=' ' ){
}
定义一个数组,数组里面包含符合文件类型的扩展名。
通过提取文件名的扩展名并判断数组中有没有存在。
如:
if(!empty($_FILES['my']['name']))//判断接收的文件名是否为空
{
$extName = array ('doc','docx','pdf'); //符合文件的扩展名数组
$tmp = explode('.',$_FILES['my']['name']);//字符串分割函数,将提交上来的文件名分割
$temp = array_pop($tmp); //将分割完的数组最后一个元素弹出
if(in_array($temp,$extName)) //判断提取的扩展名是否在符合文件的扩展名数组中
echo '文件类型符合';
else
echo '文件类型不符合';
}
通过系统全局变量$_FILE[ ' ' ][ ' size ' ] 获取
if ( $_FILE[ ' my ' ][ ' size ' ] < 1000000(一兆) );
如:规定文件大小不能超过2兆
if( $_FILES['my']['size'] < 2000000 )
echo '文件大小符合';
else
echo '文件超出文件大小';
$变量名(可替换变量) = $_FILES [ ' my ' ];
这样所有的 $_FILES[ ' my ' ][ ' name ' ]等变量均替换成 $变量名[ ' name ' ]等形式执行。
给文件名添加日期并添加随机数(使文件名不重复):
在移动接收到的文件时可以在文件名前面添加随机数,使用 rand() 。
使用date()函数,data 函数有个要求,括号内是每个单词的第一个字母,如果与前面的字母重复,就取单词下一位。(Y,H需要大写)
如:
$newname = date('YmdHis').'-'.rand(100,900).$_FILES['my']['name'];
//注意:Y,H需要大写,否则不全
if(move_uploaded_file($_FILES['my']['tmp_name'],'upload/'.$newname))
{
echo "";
}else{
echo "";
}
(1) 控件(input)中的name属性需要使用数组来定义
(2)接收需要使用三维数组($_FILES[ ' 控件中的name ' ][ ‘ name ’ ][ $变量名 ])接收上传信息。(此时$变量名是0,1,2,3等,相当于一个索引)
如:
html:
php:
echo $_FILES['my']['name'][2];// 2 可以使用一个变量来代替