Plupload,奇怪地重命名文件

时间:2017-09-19 08:05:02

标签: file rename plupload

在我负责维护的平台上,出现了一种奇怪的现象。

在网站上,我们使用plupload添加图片和文件。几天后,对于十几个用户(在奥地利,瑞士和德国等),在上传过程中,文件被重命名。

如果我发送" my_image.png",它会以此名称将其保存在存储库中,或者如果此名称下已存在另一个文件,则会添加(1)。目前,它系统地使用--1或--2 [...]重命名文件(例如:my_image - 1.png)。如果在数据库中注册文件名时将此更改考虑在内,则不会出现问题,但事实并非如此。

尽管我的同事和研究人员的帮助,但没有解释这种情况。它是超偏的,并且已经在2016年底发生而未被发现。有没有人遇到过这个问题?

我告诉你我们的plupload代码。

有关其他信息,我们的用户使用Internet Explorer(最新版本),在我们这边,没有出现错误,我们尝试重现该错误是徒劳的。

感谢您的关注

function addUpload(form_,type_,container_,button_,multiple_,ext_,params) {
    var extended_parameters = new Array();
    type_ = 'file_name_'+type_+'[]';
    return addUploadApply(form_,type_,container_,button_,multiple_,ext_,params, extended_parameters);
}

//La principale différence entre addUpload et addUploadV2 est que pour la seconde, le name fourni pour le champ (variable type_ = input_name) n'est pas réécrit par la fonction, il est utilisé tel quel ce qui est bien plus pratique pour le dévelopepment
function addUploadV2(form_id, input_name, container_id, upload_button_id, multiple_, ext_, http_get_params, extended_parameters) {
    return addUploadApply(form_id, input_name, container_id, upload_button_id, multiple_, ext_, http_get_params, extended_parameters);
}

//Cette fonction a été redéfinie dans le cadre de MultiALL
//On y ajoute un tableau de parameters afin de gérer d'éventuels paramètres supplémentaires, ce qui est compliqué à faire à l'heure actuelle
//Ca nous servira plus tard
function addUploadApply(form_,type_,container_,button_,multiple_,ext_,params, extended_parameters){ nb_upload_fields++;

    var nb_fichiers = 0;
    var total_files_size = 0;

    var file_upload = '/backoffice/upload.php?'+params;

    var uploader = new plupload.Uploader({
        multi_selection: false,
        form : form_,
        runtimes : 'gears,html5,flash,silverlight,browserplus,html4',
        browse_button : button_,
        container : container_,
        //max_file_size : '2mb',
        max_queue_size : '62914560', // 60 Mo
        url : file_upload,
        flash_swf_url : '/plupload/plupload.flash.swf',
        silverlight_xap_url : '/plupload/plupload.silverlight.xap',
        filters : [
            {title : "Files", extensions : ext_}
        ]
    });

    uploader.init();


    uploader.bind('FilesAdded', function(up, files) {

        /*$('#next_btn').hide();*/
        if(!multiple_ && nb_fichiers > 0){
            $('#'+container_+' .inputlist, #'+container_+' .filelist').html("");
            nb_fichiers = 0;
        }

        $.each(files, function(i, file) {
            total_files_size += file.size;
        });

        if(total_files_size < uploader.settings.max_queue_size){

            $.each(files, function(i, file) {

                nb_fichiers++;
                c_ = '<div class="col-md-4" id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ') <b></b>';

                if(multiple_){ $('#'+container_+' .filelist').append(c_); }
                else{ $('#'+container_+' .filelist').html(c_); }

            });

            nb_upload_uploading++;
            up.refresh(); // Reposition Flash/Silverlight
            uploader.start();

        }else{
            $.each(files, function(i, file) {
                total_files_size -= file.size;
                up.removeFile(file);
            });
            if(!$('#'+container_+' .filelist div').length) $('#'+container_+' .filelist').append('<div></div>');
            $('#'+container_+' .filelist div').prepend('<b>ERROR</b> ').css('color', '#ff0000');
            alert('Error : 11 The selected file is too big.');
            //$('#plupload_error').modal();
        }

    });

    uploader.bind('UploadProgress', function(up, file) {
        $('#'+uploader.settings.form+' #' + file.id + " b").html(file.percent + "%");
    });

    uploader.bind('Error', function(up, err) {

            $('#'+container_+' .filelist div').prepend('<b>ERROR</b> ').css('color', '#ff0000');
            alert('Error : '+obj.error.code+' '+obj.error.message);

        /*$('#'+uploader.settings.form+' #filelist').append("<div>Error: " + err.code +
            ", Message: " + err.message +
            (err.file ? ", File: " + err.file.name : "") +
            "</div>"
        );*/

        up.refresh(); // Reposition Flash/Silverlight
    });

    uploader.bind('FileUploaded', function(up, file, info) {
        $('#'+container_+' .inputlist ' + file.id + " b").html("100%");
        var obj = JSON.parse(info.response);

        // Détection d'une erreur dans le PHP
        if (obj.error !== undef) {
            $('#'+container_+' .filelist div').prepend('<b>ERROR</b> ').css('color', '#ff0000');
            alert('Error : '+obj.error.code+' '+obj.error.message);
            return false;
        }

        var c_ = '<input type="hidden" name="'+type_+'" value="' + obj.result.cleanFileName + '" class="uploadedFile ' + file.id + '" />';
        if(multiple_){ $('#'+container_+' .inputlist').append(c_); }
        else{ 
      //$('#'+container_+' .inputlist').html("");
      if ($('#'+container_+' .inputlist .uploadedFile').length && $('#'+container_+' .inputlist .uploadedFile').attr('name') != '' ) $('#'+container_+' .inputlist .uploadedFile').val(obj.result.cleanFileName); 
      else $('#'+container_+' .inputlist').html(c_);
    }
    if ($('#'+container_+' .fileRemoveButton').length) $('#'+container_+' .fileRemoveButton').show(); 
    });

    uploader.bind('UploadComplete', function(up, file) {
        nb_upload_completed++;
        if(check_upload()){ $('#next_btn').show(); }
    });

}

2 个答案:

答案 0 :(得分:0)

我不知道如何正确修复它,但我所做的并建议你做的是强制文件具有唯一的名称,以确保不会发生冲突。

您可以通过在每个文件中附加伪随机哈希来实现,从而使其名称随机(但仍保留原始名称)。这样可以防止碰撞,您可以完全控制和了解最终文件。

答案 1 :(得分:0)

问题已解决,并且没有来自插件。另一位开发人员修改了(当我生病时)重复内容的代码。它改变了,不考虑周围的事情,从那以后,它已经不再适用了。

感谢您的关注和帮助。