簡體   English   中英

move_uploaded_file(); 不工作

[英]move_uploaded_file(); not working

我剛剛編寫了一個腳本來上傳圖像,並且已經檢查了很長時間,但是我找不到錯誤在哪里。 整個代碼執行了應該執行的操作,但move_uploaded_file(); 功能沒有。 這是我的代碼:

HTML:

<form method="post" id="img-form" enctype="multipart/form-data">
Subir imagen: <input type="file" name="file">
</form>
<div id="respuesta"></div>

JS:

$(function(){
$("input[name='file']").on("change", function(){
var formData = new FormData($("#img-form")[0]);
$.ajax({
    url: "ajax/uploadimage.php",
    type: "POST",
    data: formData,
    contentType: false,
    processData: false,
    success: function(data)
       {
         $("#respuesta").html(data);
       }
    });
 });
});

PHP:

<?php
require '../init.php';

if (isset($_FILES["file"]))
{
    $file = $_FILES["file"];
    $nombre = $file["name"];
    $type = $file["type"];
    $ruta_provisional = $file["tmp_name"];
    $size = $file["size"];
    $gethandw = getimagesize($ruta_provisional);
    $width = $gethandw[0];
    $height = $gethandw[1];
    $path = "img/users/";

    if ($type != 'image/jpg' && $type != 'image/jpeg' && $type != 'image/png' && $type != 'image/gif')
    {
      echo "Error, el archivo no es una imagen"; 
    }
    else if ($size > 1024*1024)
    {
      echo "Error, el tamaño máximo permitido es un 1MB";
    }
    else if ($width > 400 || $height > 400)
    {
        echo "Error la anchura y la altura maxima permitida es 500px";
    }
    else if($width < 60 || $height < 60)
    {
        echo "Error la anchura y la altura mínima permitida es 60px";
    }
    else
    {
        $src = $path.$nombre;
        move_uploaded_file($ruta_provisional, $src);
        echo "<img src='$src'>";
    }
}

答案(數據)輸出一切正確,但圖像未上傳到任何地方,我正在使用xampp進行測試

您的PHP代碼似乎還可以。 我發現您的FormData實現存在一些問題。 請嘗試以下代碼

JS

$(function(){
    $("input[name='file']").on("change", function() {
        var formData = new FormData();
        formData.append('file', $(this)[0].files[0]); 
        $.ajax({
            url: "ajax/uploadimage.php",
            type: "POST",
            data: formData,
            contentType: false,
            processData: false,
            success: function(data) {
                $("#respuesta").html(data);
            }
        });
     });
});

如果您仍然遇到困難,請告訴我。 希望這會有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM