5

我正在尝试使用 CI 2.1.3 使用进度条上传文件。我已经让文件上传一切正常,但是获得这个文件进度并不容易。我查看了大量具有不同解决方案的指南,但它们似乎都不起作用,因为大多数都非常过时(2008 年左右)。

这就是我要找的东西:

  • PHP/jQuery/AJAX/Javascript 解决方案(请不要使用 Flash!)
  • 跨浏览器(IE 不是问题,所以如果它在 IE8 或更低版本中不起作用,那也没关系)
  • CodeIgniter 上传库兼容

就是这样。我的参考代码:

PHP:

public function do_upload()
{
    // Configure and load the uploads library
    $config['upload_path']   = './uploads/';
    $config['allowed_types'] = 'mp4|mov';
    $config['encrypt_name']  = TRUE;
    $config['max_size']      = '2621440'; // 2.5 GB, in kilobytes

    $this->load->library('upload', $config);

    if (!$this->upload->do_upload('userfile'))
    {
        $this->session->set_flashdata('error', $this->upload->display_errors('', ''));

        redirect('upload');
    }
    else
    {
        $this->session->set_flashdata('upload_data', $this->upload->data());

        $upload_data = $this->upload->data();
        $uploader = $this->flexi_auth->get_user_by_id()->row_array()['uacc_username'];

        $this->load->model('upload_model');
        $this->session->set_flashdata('uaid', $this->upload_model->generate_uaid($upload_data['raw_name']));
        $this->upload_model->create_upload($upload_data['file_name'], $upload_data['raw_name'], $upload_data['client_name'], $upload_data['file_size'], $upload_data['file_path'], $uploader);

        redirect('upload');
    }
}

HTML:

<div class="progress progress-striped active" id="upload_progress" style="display: none;">
                    <div class="bar" id="upload_progress_bar" style="width: 0%;"></div>
                </div>
                <?php echo form_open_multipart('upload/do_upload', array('id' => 'upload_form')); ?>
                <input type="file" name="userfile" size="20" />
                <button type="submit" name="upload">Upload</button>
                <?php echo form_close(); ?>
4

2 回答 2

3

实际上,经过进一步研究,Dropzone.JS似乎与 CI 配合得非常好,几乎不需要配置和调整。我还没有机会使用它的所有功能,但是在大约 5 分钟的工作之后,它就有了上传进度,并且拖放上传工作正常。

于 2013-04-13T12:45:11.967 回答
1

http://vortexdev.netii.net/article_20/Integrate_jQuery_File_Upload_with_CodeIgniter
- 2012/05/14

https://github.com/blueimp/jQuery-File-Upload/wiki/jQuery-File-Upload-6.5-with-CodeIgniter-2.1
- 5 个月前编辑

这是一个艰难的。有很多解决方案,但很大程度上取决于堆栈和目标(例如,在您的情况下没有闪存)。有一个PECL 扩展提供了本机功能,以及许多其他尝试做同样事情例子,这些例子在去年一直很活跃。还有声称提供基于 PHP 的输出控制的直接 html 进度。我无法让它在本地工作。

最好的办法是开始将东西混合在一起并尝试得到一些有效的东西——目前还没有一个直接的即插即用解决方案用于 CI 上传进度条。

于 2013-04-11T14:09:14.463 回答