在我负责维护的平台上,出现了一种奇怪的现象。
在网站上,我们使用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(); }
});
}
答案 0 :(得分:0)
我不知道如何正确修复它,但我所做的并建议你做的是强制文件具有唯一的名称,以确保不会发生冲突。
您可以通过在每个文件中附加伪随机哈希来实现,从而使其名称随机(但仍保留原始名称)。这样可以防止碰撞,您可以完全控制和了解最终文件。
答案 1 :(得分:0)
问题已解决,并且没有来自插件。另一位开发人员修改了(当我生病时)重复内容的代码。它改变了,不考虑周围的事情,从那以后,它已经不再适用了。
感谢您的关注和帮助。