我遇到以下问题。我使用带有四个经验证的文本输入字段的输入表单(不允许为空),以及同一表单下面的三个文件输入字段。当我尝试上传尺寸较小的图像时,一切正常。但是当我选择较大的图片时,如1MB左右,即使我填写了文本输入字段,我也会收到验证错误。
$ime = mysql_real_escape_string($_POST['ime']);
$mesto = mysql_real_escape_string($_POST['mesto']);
$telefon = mysql_real_escape_string($_POST['telefon']);
$emajl = mysql_real_escape_string($_POST['emajl']);
$opis = mysql_real_escape_string($_POST['opis']);
if ((empty($ime)) || (empty($mesto)) || (empty($telefon)) || (empty($emajl))){echo "Moraju biti uneti podaci u obavezna polja"; exit;}
//unos slike1
if ((($_FILES["slika1"]["type"] == "image/gif")
|| ($_FILES["slika1"]["type"] == "image/jpeg")
|| ($_FILES["slika1"]["type"] == "image/jpg")
|| ($_FILES["slika1"]["type"] == "image/pjpeg")
|| ($_FILES["slika1"]["type"] == "image/x-png")
|| ($_FILES["slika1"]["type"] == "image/png"))
&& ($_FILES["slika1"]["size"] < 2097152))
{
if ($_FILES["slika1"]["error"] > 0)
{
echo "Greška: " . $_FILES["slika1"]["error"] . "<br>";
}
else
{
$razdvajanje = explode('.',$_FILES['slika1']['name']);
$ekstenzija = $razdvajanje[1];
$novoime = mysql_real_escape_string($razdvajanje[0]).'_'.time();
$putanja = 'uploads/' . $novoime . "." . $ekstenzija;
move_uploaded_file($_FILES['slika1']['tmp_name'], $putanja);
}
}
else
{
echo "Slika mora biti manja od 2MB i u adekvatnom formatu";
我得到的错误是“Moraju biti uneti podaci u obavezna polja”即使这个领域也不是空的。当我尝试上传一个更大的图像时,它也有效。当我尝试同时上传三个1MB图像时,它才起作用。
要清楚。脚本正在使用localhost(XAMPP)。上传到我的网络托管服务器时遇到问题。此外,当我上传3个大约300kb的图像文件时,脚本正在工作,但是当我尝试上传3个大小约为1MB的文件时,该过程失败了大约60%。我不认为问题的大小,而是上传时间。
答案 0 :(得分:0)
也许您需要增加php.ini中允许的大小 或做这样的事情
ini_set('post_max_size', '10M');
ini_set('upload_max_filesize', '10M');
ini_set('max_file_uploads', '20');
答案 1 :(得分:0)
您必须设置filesize并覆盖PHP设置的默认大小:
这样的事情:
$size1=$_FILES["uploaded_file"]["size"]/1024;
$max_allowed_file_size = 50000;
if($size1 >= 0)
{
if($size1> $max_allowed_file_size )
{
$err[]= "\n Size of file should be less than $max_allowed_file_size";
}
}
只需使用文件大小修改脚本,你应该没问题。
答案 2 :(得分:0)
这样做:
希望这有帮助。
答案 3 :(得分:0)
我通过将图像大小限制为500kb来解决问题。它现在有效。我的意思是,我没有解决问题,我避免了。