如果数据库中没有映像,则尝试上载映像时出错

时间:2013-11-16 18:00:44

标签: php mysql file-upload

我创建了一个将图像上传到我的数据库表的函数,但是当表中的图像字段为空时,它给出了一个错误,这里是代码:

$consulta_img = "SELECT `poster`, `screenshot1`, `screenshot2`, `screenshot3`, `screenshot4`, `screenshot5`, `screenshot6`, `screenshot7`, `screenshot8` FROM `serie` WHERE `id`='$_POST[id_editar]'";
$imagenes = mysql_query ($consulta_img);
$imagen = mysql_fetch_array($imagenes);


function actualizar_imagen($imagen_cargada){
    $fecha=date("Y_m_d_H_i_s_");
    if($_FILES[$imagen_cargada]['name'] != ""){
        global $imagen;
        $imagen_actual = $imagen[$imagen_cargada];
        unlink("../publico/img/".$imagen_actual);
        $imagen_final = $fecha . $_FILES[$imagen_cargada]['name'];
        move_uploaded_file($_FILES[$imagen_cargada]['tmp_name'], '../publico/img/' . $imagen_final);
    }else{
        $imagen_final = $fecha . $_FILES[$imagen_cargada]['name'];
        move_uploaded_file($_FILES[$imagen_cargada]['tmp_name'], '../publico/img/' . $imagen_final);
    }
    return $imagen_final;
}

我回来的错误是:

 Warning: unlink(../publico/img/2013_11_16_15_56_53_CIMG1884.JPG) [function.unlink]: No such file or directory in C:\AppServ\www\dejavu\administrador\editar.php on line 19

这是完全合乎逻辑的,图像不存在,但这意味着其他方法不起作用,我无法弄清楚原因。


这是UPDATE查询部分:

$campo = $_GET['img_borrar'];
$consulta_levantar_imagen = "SELECT `$campo` FROM `serie` WHERE `id`= $_GET[id_usuario_eli_img]";
$imagenes = mysql_query($consulta_levantar_imagen);
$imagen = mysql_fetch_array($imagenes);
$nombre_imagen = $imagen[$campo];

$consulta = "UPDATE `serie` SET  `$campo` = '' WHERE `id` = $_GET[id_usuario_eli_img]";
$borrar_img_ok = mysql_query($consulta);
unlink("../publico/img/".$nombre_imagen);

if($borrar_img_ok){
    header("Location:listado.php?editado=ok");
}

1 个答案:

答案 0 :(得分:1)

您最有可能尝试的是以下内容:

function actualizar_imagen($imagen_cargada) {
    global $imagen;

    if ($imagen[$imagen_cargada] != '') {
        // If no value in the database
        $imagen_actual = $imagen[$imagen_cargada];
        unlink("../publico/img/".$imagen_actual);
    }

    // Following part can be outside if-statement, because you call it
    // wheter the image already exists or not
    $fecha=date("Y_m_d_H_i_s_");
    $imagen_final = $fecha . $_FILES[$imagen_cargada]['name'];
    move_uploaded_file($_FILES[$imagen_cargada]['tmp_name'], '../publico/img/' . $imagen_final);

    return $imagen_final;
}

您目前拥有的是

if ($_FILES[$imagen_cargada]['name'] != "") {
     // If the name of the uploaded file is not empty
     unlink(...);
}