php个人照片上传代码的解析,php 文件上传的实例解析

本文介绍了PHP实现文件上传的步骤,包括HTML表单的创建和PHP处理程序upload.php。在表单中设置了文件类型限制和最大上传大小,并通过PHP函数检查文件类型和生成随机文件名以避免重名。程序利用`$_FILES`超全局数组获取上传信息,通过`move_uploaded_file()`将文件移动到指定目录,成功上传后输出预览。文章深入解析了`strrchr()`和`substr()`等函数的作用,以及如何防止文件重名和确保上传安全。

1,php文件上传的表单代码:

文件:

< input type="submit" value="上传" name="B1">

首先,

,采用POST方法,个别浏览器还支持PUT方法。

表单中必须设置enctype="multipart/form-data,服务器就知道上传文件带有常规表单信息。

此外还需要一个隐藏域来限制上传文件的最大长度:,这里name必须设置成MAX_FILE_SIZE,其值就是上传文件的最大长度,单位是B,这里我限制成2M。再看这句:,type="file"说明了文件类型,这样一个基本的上传文件接口就完成了。

如何用PHP来处理上传的文件,php.ini中设置的上传文件最大长度可能会影响到实际上传,请根据实际情况修改。

另PHP的上传是先传到临时目录,然后才移至指定目录;临时目录的可根据需要修改,也可使用默认值。

2,php文件上传的表单提交程序upload.php:

//文件上传

$uploaddir = "./files/";//设置文件保存目录 注意包含/

$type=array("jpg","gif","bmp","jpeg","png");//设置允许上传文件的类型

$patch="http://127.0.0.1/cr_downloadphp/upload/files/";//程序所在路径

//获取文件后缀名函数

function fileext($filename)

{

return substr(strrchr($filename, '.'), 1);

}

//生成随机文件名函数

function random($length)

{

$hash = 'CR-';

$chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';

$max = strlen($chars) - 1;

mt_srand((double)microtime() * 1000000);

for($i = 0; $i < $length; $i++)

{

$hash .= $chars[mt_rand(0, $max)];

}

return $hash;

}

$a=strtolower(fileext($_FILES['file']['name']));

//判断文件类型

if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))

{

$text=implode(",",$type);

echo "您只能上传以下类型文件: ",$text,"
";

}

//生成目标文件的文件名

else{

$filename=explode(".",$_FILES['file']['name']);

do

{

$filename[0]=random(10); //设置随机数长度

$name=implode(".",$filename);

//$name1=$name.".Mcncc";

$uploadfile=$uploaddir.$name;

}

while(file_exists($uploadfile));

if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile)){

if(is_uploaded_file($_FILES['file']['tmp_name']){

//输出图片预览

echo "

您的文件已经上传完毕 上传图片预览:
%24uploadfile
";

echo"

继续上传
";

}

else{

echo "上传失败!";

}

}

}

?>

原理,该程序以上传图片为例,先判断文件类型是否为图片格式,若是则上传文件,以随机数和时间的组合重新命名文件(避免上传文件重名),接着上传文件到指定目录,成功上传则输出上传的图片预览。

先看return substr(strrchr($filename, '.'), 1), strrchar()函数有什么作用呢,比如一个图片文件 pic.jpg,用 strrchr处理,strrchr(pic.jpg,'.'),它将返回.jpg,明白了吗?该函数返回指定字符在该字符串最后出现的位置后的字符。配合 substr() 就可以取到jpg,就得到了文件的后缀名,来判断上传文件是否符合指定格式。

本程序把指定的格式放在一个数组中,实际使用时可根据需要添加。

接下来看产生随机数文件名部分, 看到mt_srand()这个函数,手册上叫他“播下一个更好的随机数发生器种子”,其实就是初始化一个随机数的函数,参数是(double)microtime() * 1000000,这里如果不这是参数就会自动设置个随机数,当然这不符合我们的需要,如此一来,随机数就具备一定的长度,保证了上传文件不重名。

接着,我们调用判断文件类型的函数,并将其转化为小写strtolower(fileext($_FILES['file']['name'])),这里有个很关键的东东$_FILES ,这是个超级全局数组,保存了需要处理的表单数据,如果开启了register_globals,也可以直接访问,但这是不安全的。

看刚才那个上传接口,根据此表单名称,可以得到很多信息:

$_FILES['file']['name']--   得到文件名称

$_FILES['file']['tmp_name']--得到临时存储位置

$_FILES['file']['size']--得到文件大小

$_FILES['file']['type']--得到文件MIME类型

file_exists()--判断指定目录是否存在,move_uploaded_file--将上传文件移至指定目录,is_uploaded_file--判断文件是否已经通过HTTP POST上传。

成功上传,输出预览,否则输出上传失败。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值