jquery文件上传 - 如何覆盖文件不重命名

Posted

技术标签:

【中文标题】jquery文件上传 - 如何覆盖文件不重命名【英文标题】:jquery file upload - how to overwrite file NOT rename 【发布时间】:2013-01-25 01:46:28 【问题描述】:

我正在努力更新 Jquery 文件上传插件,因此当您上传文件时,它只会覆盖具有相同名称的现有文件,而不是使用 upcount 重命名它。

我已应用此链接中涵盖的更改:https://github.com/blueimp/jQuery-File-Upload/issues/1965

但我似乎无法覆盖此插件以使其正常工作?

这里有一个尚未回答的现有问题:jQuery File Upload by bluimp, how to replace instead of renaming

任何有关这方面的指导将不胜感激。

【问题讨论】:

您是否找到了覆盖文件的解决方案?我也需要。谢谢 看看这里:***.com/a/47333596/2065594 【参考方案1】:

Anno 2018 这也可以工作(php 7.1):

class MyUploadHandler extends UploadHandler

    public function __construct($options = array(), $initialize = true, $error_messages = null) 
        $options += array(
            'overwrite_existing' => true
        );

        parent::__construct($options, $initialize, $error_messages);
    

    protected function get_unique_filename($file_path, $name, $size, $type, $error, $index, $content_range) 
        if ($this->options['overwrite_existing'] ?? false) 
            return $name;
        

        return parent::get_unique_filename($file_path, $name, $size, $type, $error, $index, $content_range);
    

它避免了必须更改原始代码,然后可以将其用作库。

【讨论】:

【参考方案2】:

2016 更新到 MKoosej 的修复! 在 UploadHandler.php → 受保护的函数 get_file_name ... 替换

return $this->get_unique_filename(
        $file_path,
        $this->fix_file_extension($file_path, $name, $size, $type, $error,
            $index, $content_range),
        $size,
        $type,
        $error,
        $index,
        $content_range
    );

return $this -> trim_file_name($file_path, $name, $size, $type, $error, $index, $content_range);

【讨论】:

其他解决方案不再适用于新版本 (2016+) 的上传。这个可以。【参考方案3】:

我尝试了@MKoosej 的解决方案。就我而言,它工作得很好,但我还编辑了trim_file_name,我让它只返回一个文件名(我必须做一个上传器,将任何文件名转换为data.csv)。此外,我必须制作其他版本的上传器,我应该重写文件名而不是重命名,但不同名称的不同文件应该保持不同。所以当我在那里尝试@MKoosej 解决方案时,它开始上传只有扩展名的文件,比如没有文件名的.jpeg。 所以,我找到了这个解决方案: 在 func get_unique_filename 一开始我放了这个:

$oldName=$name;

并返回$oldName 而不是$name,这很好。

【讨论】:

【参考方案4】:

查看 github (here) 上的文档并向下滚动到“如何在上传的生命周期中将文件绑定到元素节点”的位置。这是代码:

$(function () 
    $('#fileupload').fileupload(
        dataType: 'json',
        add: function (e, data) 
            data.context = $('<p/>').text('Uploading...').appendTo(document.body);
            data.submit();
        ,
        done: function (e, data) 
            data.context.text('Upload finished.');
        
    );
);

注意done回调函数。如果您展开 data 对象,您会注意到有一个 data.files 对象以及一个 data.result 对象。 data.result 包含服务器上的文件 的名称。因此,根据上面给出的示例脚本,服务器上新上传的文件的名称是 data.result.files[0].name

我希望这对某人有所帮助

【讨论】:

【参考方案5】:

如果您使用 wiki 中存在的 UploadHandler.php,这很简单。在 get_file_name 方法中,您应该替换这一行:

    return $this -> get_unique_filename($this -> trim_file_name($name, $type, $index, $content_range), $type, $index, $content_range);

用这个:

 return $this -> trim_file_name($name, $type, $index, $content_range);

【讨论】:

大声笑,伙计,你的解决方案帮助了我,但实际上这对我来说不起作用。那我自己写答案。【参考方案6】:

我需要相同的文件覆盖选项。

使用 PHP UploadHandler.php 文件,我做了一个非常适合我的快速破解。 我确信有更好的方法,但这可能对其他人有所帮助。

查找处理程序“upcount_name_callback”并将返回语句替换为取出的(索引)编号。我留下了原来的退货声明,以防我需要回去:)

protected function upcount_name_callback($matches) 
    $index = isset($matches[1]) ? intval($matches[1]) + 1 : 1;
    $ext = isset($matches[2]) ? $matches[2] : '';
    return ''.$ext;
    /* return ' ('.$index.')'.$ext; */

【讨论】:

【参考方案7】:

只需在回调中执行 ajax 请求即可开始上传并从数据盘中删除文件。您可以使用 data.files[0].name 找到文件名。

然后你只需搜索带有旧链接的 tr,如下所示:

$("a[title='"+ data.files[0].name + "']").each(function () 
        $(this).closest('tr').fadeOut();
    );

然后淡出。

问候

【讨论】:

很抱歉,但我无法弄清楚表格行上的 DOM 操作与手头的问题有什么关系,甚至你的建议上传前删除文件...

以上是关于jquery文件上传 - 如何覆盖文件不重命名的主要内容,如果未能解决你的问题,请参考以下文章

如何自动给文件命名,避免覆盖同名文件?

如何重命名文件并覆盖 VBS 中的现有文件?

如何覆盖 ICEfaces 中的默认文件上传 h:message

在 Azure Blob 存储中覆盖后如何命名 csv 文件

Java SFTP使用JSch上传,但是如何覆盖当前文件?

如何使用来自谷歌的外部托管 jquery 覆盖核心 jquery 文件