我使用PHP上传文件,但我想只允许使用PDF,DOC,DOCX。 我在这里找到了一些答案,但没有一个能帮助我。
这是我的代码:
$from = str_replace(array("\r", "\n"), '', $mail); // to prevent email injection
if ($file) {
$filename = basename($_FILES['fileupload']['name']);
$file_size = filesize($file);
$content = chunk_split(base64_encode(file_get_contents($file)));
$uid = md5(uniqid(time()));
$header = "MIME-Version: 1.0\r\n"
."From: {$name}<{$from}>\r\n"
."Content-Type: multipart/mixed; boundary=\"".$uid."\"\r\n\r\n"
."This is a Mime.\r\n\r\n"
."--".$uid."\r\n"
."From: {$name}<{$from}>\r\n"
."Content-type:text/html; charset=UTF-8\r\n\r\n"
.$msg1."\r\n\r\n"
."--".$uid."\r\n"
."Content-Type: application/octet-stream; name=\"".$filename."\"\r\n"
."Content-Transfer-Encoding: base64\r\n"
."Content-Disposition: attachment; filename=\"".$filename."\"\r\n\r\n"
.$content."\r\n\r\n"
."--".$uid."--";
$msg1 = '';
} else {
$header = "MIME-Version: 1.0\r\n";
$header .= "Content-type: text/html; charset=UTF-8\r\n";
$header .= "From: <".$mail. ">" ;
}
答案 0 :(得分:4)
您可以使用以下代码检查上传的文件是否正确。
$FileType = pathinfo($filename,PATHINFO_EXTENSION);
if($FileType != "pdf" && $FileType != "doc" && $FileType != "docx") {
echo "Sorry, only PDF, DOC, DOCX files are allowed.";
}
答案 1 :(得分:2)
使用“类型”查找正在上传的文件类型。如果是PDf / Mswrod,则继续使用您的代码,否则向用户显示只允许PDF和文档的错误。顺便说一下,请尝试上传文档和文档,并尝试打印他们的类型,如果他们的类型是我在“If”条件中没有涵盖的类型,那么请使用“OR”将它们添加到现有的“If”条件中( ||)。
if (($_FILES["file"]["type"] == "application/pdf" || $_FILES["file"]["type"] == "application/msword")
{
// If file is Pdf or Doc, process your code
}
else
{
$type = $_FILES["file"]["type"];
echo "Your file type is ".$type." while we only accept PDF and Doc.<br/>";
die('Try Again');
}