php文件上传实例(带文件类型限制)
这个文件上传实现可用于实例应用开发中了,因为做了比较好的安全限制了,当然大家还可以对上传图片文件进行类型获取判断了。
今天改进了下旗下几个网站的文件上传系统,顺便发点东西。
全php代码,无js,文件类型根据后缀名判断,非mime判断。
新建个up.php,代码如下:
<?php
$uptype = array(
"jar",
"zip"
);
//允许上传文件类型
$max_file_size = 20480000; //上传文件大小限制, 单位BYTE
$path_parts = pathinfo($_SERVER['PHP_SELF']); //取得当前路径
$destination_folder = "files/";
//上传文件路径
$name = "MuXi_" . date("Y-m-d_H-i-s");
//保存文件名
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$file = $_FILES["upload_file"];
if (!is_uploaded_file($file["tmp_name"]))
//是否存在文件
{
echo "文件不存在!";
exit;
}
$torrent = explode(".", $file["name"]);
$fileend = end($torrent);
$fileend = strtolower($fileend);
if (!in_array($fileend, $uptype))
//检查上传文件类型
{
echo "不允许上传此类型文件!";
exit;
}
if ($max_file_size < $file["size"])
//检查文件大小
{
echo "文件太大,超过上传限制!";
exit;
}
if (!file_exists($destination_folder)) mkdir($destination_folder);
$filename = $file["tmp_name"];
$image_size = getimagesize($filename);
$pinfo = pathinfo($file["name"]);
$ftype = $pinfo[extension];
$destination = $destination_folder . $name . "." . $ftype;
if (file_exists($destination) && $overwrite != true) {
echo "同名文件已经存在了!";
exit;
}
if (!move_uploaded_file($filename, $destination)) {
echo "移动文件出错!";
exit;
}
$pinfo = pathinfo($destination);
$fname = $pinfo[basename];
echo "上传成功!";
}
?>调用代码:
<form action="up.php" method="post" enctype="multipart/form-data"> <input type="file" name="upload_file" /> <input type="submit" value="上传" />
用mime类型限制有局限性,有些文件在上传是不是正常本身的mime,导致上传不成功,而用后缀名限制可以很好的解决这个问题。
本文地址:http://www.phprm.com/code/54694.html
转载随意,但请附上文章地址:-)