【问题标题】:Progress bar in uploading files using URL使用 URL 上传文件的进度条
【发布时间】:2013-08-13 12:04:33
【问题描述】:

我正在通过 PHP、ajax 中的 URL 上传文件。我需要一个进度条来显示已上传了多少文件。

请查看我在代码中使用的内容。

PHP 代码

$upload_url = $_REQUEST['upload_url'];

$arr_upload_file = explode("/",$upload_url);
$ext = $arr_upload_file[count($arr_upload_file)-1];
$file = md5(mt_rand(0,1000) . implode(getdate()) . $ext) . '-' . $ext;
//echo $_SERVER[']
$app->sessions->get_var('folder_id');
$path = 'C:/wamp/www/bigoshare/uploads/';

$uploadss = file_put_contents($path.$file,file_get_contents($upload_url));
$size = getimagesize($path.$file);
$totsize = strlen(file_get_contents($upload_url));

Ajax 代码

$('#url_upload_btn').live('click', function () {

    $('#progress_container').fadeIn(100); //fade in progress bar
    $('#progress_bar').width("50%"); //set width of progress bar based on the $status value (set at the top of this page)
    $('#progress_completed').html("50%");
    upload_url = $('#txt_url_link').val();
    setInterval("getinterdata()", 1000);
    var dataString = 'upload_url=' + upload_url;
    $.ajax({
        url: App.url + '/allusers/uploadbyurl/',
        type: 'GET',
        data: dataString,
        success: function (data) {

            $('#uploads').prepend($.trim(data));

            $('.show_url_Upload_div').hide();
        }
    });


});

function getinterdata() {

    $.ajax({
        url: App.url + '/allusers/getuploadpercentage/',
        type: 'GET',
        success: function (data) {
            console.log(data);
        }

    });

}

当我执行上述代码时,第二个 ajax 仅在文件上传完成后响应,而我需要在上传时和进行中。

【问题讨论】:

  • 没有给你html代码。我认为您的 progress_container id 丢失了
  • 主要问题是第二个 ajax 没有响应,直到第一个 ajax 没有完成。

标签: php jquery ajax file url


【解决方案1】:

不要重新发明轮子 ;) 有几十个经过测试和调试的带有进度条的 jquery 文件上传插件。随便挑一个吧。

我个人非常喜欢 [1] 这个。简单易用、良好的文档和足够强大的功能。

您可能想查看 [2]:“how-to-display-upload-progress-with-the-basic-plugin”中的块应该很有帮助!

[1]http://blueimp.github.io/jQuery-File-Upload/

[2]https://github.com/blueimp/jQuery-File-Upload/wiki/Basic-plugin

【讨论】:

  • 我可以管理存储在我们服务器上的文件的进度条。问题是 > 我正在从 url 上传文件。
  • 提交上传的值的来源应该容易改吗?当你从本地文件系统中选择一个文件时,它应该使用某种“url”......但仍然:你可以去看看插件如何处理同时处理这两个动作的问题。
猜你喜欢
  • 2012-12-02
  • 2013-03-02
  • 1970-01-01
  • 2011-02-24
  • 1970-01-01
相关资源
最近更新 更多