我希望对包含文件上传的PHP脚本进行HTTP POST。 PHP脚本应该拒绝任何不正确类型或其他格式错误的文件。
这意味着
我如何做到这些?
答案 0 :(得分:3)
PHP无法中止上传。但是,您可以在文件完全上传后验证$_FILES
。
此功能可让人们上传文本和二进制文件。使用PHP的身份验证和文件操作功能,您可以完全控制允许上传的人员以及文件上传后的内容。
请参阅:
http://php.net/manual/en/features.file-upload.post-method.php
您可以在php.ini中限制文件大小
upload_max_filesize integer
上传文件的最大大小。 使用整数时,该值以字节为单位。也可以使用本FAQ中描述的速记符号。
http://www.php.net/manual/en/ini.core.php#ini.upload-max-filesize
答案 1 :(得分:0)
这是你可以获得的最大值。
<?php
$allowedExts = array("jpg", "jpeg", "gif", "png");
$extension = end(explode(".", $_FILES["file"]["name"]));
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000)
&& in_array($extension, $allowedExts))
{
if ($_FILES["file"]["error"] > 0)
{
echo "Error: " . $_FILES["file"]["error"] . "<br />";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
echo "Stored in: " . $_FILES["file"]["tmp_name"];
}
}
else
{
echo "Invalid file";
}
?>