用户
 找回密码
 入住 CI 中国社区
搜索
查看: 8154|回复: 3
收起左侧

[初级] 在CodeIgniter框架中使用plupload插件上传文件到七牛云存储

[复制链接]
发表于 2014-11-30 02:49:15 | 显示全部楼层 |阅读模式
本帖最后由 8966092 于 2014-11-30 02:51 编辑

最近想做个相册系统,平时都是使用ThinkPHP来开发的,但是这次想换一个PHP框架试试,于是选择了CodeIgniter框架,因为熟悉了TP框架,所以CodeIgniter学起来也相对容易点.
网上搜了一下,几乎没有CodeIgniter结合七牛的案例,加上自己也是初次使用CodeIgniter和七牛,所以花了一整天的时间在研究这个,用到的上传插件是Plupload,在这里分享给大家,希望对大家有帮助。
修改七牛php-sdk
首先下载七牛的php-sdk,将压缩包内的qiniu文件夹放置到CodeIgniter框架application\libraries\文件夹下.因为CodeIgniter的类库对命名有要求,而七牛sdk的类库文件名和类名不一致,所以需要稍微修改下sdk里面的文件名.

将io.php修改为Qiniu_PutExtra.php
将rs.php修改为Qiniu_RS_GetPolicy.php
将fop.php修改为Qiniu_ImageView.php

引入Plupload并初始化
HTML复制代码
 
<script type="text/javascript" src="<?php echo base_url(); ?>public/js/jquery-1.11.1.min.js" ></script>
<script type="text/javascript" src="<?php echo base_url(); ?>public/js/plupload/plupload.full.min.js" ></script>
<script type="text/javascript" src="<?php echo base_url(); ?>public/js/plupload/jquery.plupload.queue/jquery.plupload.queue.min.js" ></script>
<script type="text/javascript" src="<?php echo base_url(); ?>public/js/plupload/i18n/zh_CN.js" ></script>
<link rel="stylesheet" href="<?php echo base_url(); ?>public/js/plupload/jquery.plupload.queue/css/jquery.plupload.queue.css" />
 
 
复制代码


在模板中添加标签,用于显示上传区域
HTML复制代码
 
<div id="muilti_uploader">
    <p>你的浏览器没有安装Flash插件,或不支持HTML5</p>
</div>
 
 
复制代码


设置参数,初始化Plupload
JS复制代码
 
<script type="text/javascript">
$(function() {
    var photos = Array(); // 用于存放照片信息
    // 设置参数,初始化Plupload
    $("#muilti_uploader").pluploadQueue({
        runtimes : 'html5,flash,silverlight,html4',
        url : "http://up.qiniu.com/",
        chunk_size : '512kb',
        rename : true,
        dragdrop: true,
        filters : {
            max_file_size : '10mb',
            mime_types: [
                {title : "Image files", extensions : "jpg,jpeg,gif,png"},
                {title : "Zip files", extensions : "zip"}
            ]
        },
        multipart: true,
        multipart_params: {
            'token': '<?php echo $upToken;?>', //token,需要从服务器获取
        },
        flash_swf_url : '<?php echo base_url(); ?>public/js/plupload/Moxie.swf'
    });
 
    var uploader = $('#muilti_uploader').pluploadQueue();
    //上传文件之前触发
    uploader.bind('BeforeUpload', function(uploader, file){
        var file_ext = file.name.substr(file.name.lastIndexOf(".")); // 图片后缀
        //指定文件的名称,如果不设置,七牛会默认将文件的hash值作为文件的名字
        uploader.settings.multipart_params.key = parseInt(new Date().valueOf()/1000) + '-' + parseInt(Math.random()*8999 + 1000) + file_ext;
    });
    //成功上传一个文件后触发
    uploader.bind('FileUploaded', function(uploader, file, responseObject) {
        //将七牛返回的json数据转换成对象
        var res = eval('('+responseObject.response+')');
        //组合文件信息
        var photo = new Object();
        //因为在数据库中,我用字段名name来存储文件名,用path来存储七牛上的文件名
        //所以这里的photo对象属性为name和path,如果你用的字段名和我的不一样,请自行修改
        photo.name = file.name; // 上传之前的图片名称
        photo.path = res.key; // 保存后的图片名称(含前缀)
        photos.push(photo); //将对象压入到photos数组
 
    });
    //全部文件上传完成后触发
    uploader.bind('UploadComplete', function(uploader, file){
        //文件全部成功上传后,将数据传递给CI框架进行处理
        $.ajax({
            url: "<?php echo site_url('photo/save'); ?>", //ci框架处理地址
            type: "POST",
            data: {files:JSON.stringify(photos)},
            success: function(msg){
                alert(msg);
            }
        });
    });
});
</script>
 
 
复制代码

CodeIgniter代码部分
在控制器中编写一个方法,用来显示刚才的视图页面.
PHP复制代码
 
/**
 * 上传照片页面
 * @return void
 */

public function upload()
{
    //载入七牛sdk类库
    $this->load->library('qiniu/Qiniu_PutExtra');
    $this->load->library('qiniu/Qiniu_RS_GetPolicy');
 
    //配置七牛云存储,请查看自己的七牛账号
    $bucket = ""; //你的七牛云存储的空间名称
    $accessKey = ''; //公钥
    $secretKey = ''; //密钥
 
    Qiniu_SetKeys($accessKey, $secretKey);
    $putPolicy = new Qiniu_RS_PutPolicy($bucket);
    //生成token
    $data['upToken'] = $putPolicy->Token(null);
 
    //载入视图
    $this->load->view('photo_upload', $data);
}
 
 
复制代码


编写一个方法,用来存储文件信息到自己的数据库.
PHP复制代码
 
/**
 * 保存照片
 * @return string
 */

public function save()
{
    //载入七牛SDK类库
    $this->load->library('qiniu/Qiniu_RS_GetPolicy');
    $this->load->library('qiniu/Qiniu_ImageView');
 
    $bucket = ""; //你的七牛云存储的空间名称
    $domain = ''; //你的七牛云存储空间的地址
    $accessKey = ''; //公钥
    $secretKey = ''; //密钥
    Qiniu_SetKeys($accessKey, $secretKey);
 
    $imgInfo = new Qiniu_ImageInfo;
 
    // 组合数据
    if (isset($_POST['files']) && !empty($_POST['files'])) {
        $files = json_decode($_POST['files'], true);
        foreach ($files as $key => $value) {
            //生成baseUrl
            $baseUrl = Qiniu_RS_MakeBaseUrl($domain, $value['path']);
            //生成fopUrl
            $imgInfoUrl = $imgInfo->MakeRequest($baseUrl);
            //获取七牛上的图片属性
            // format       图片类型,如png、jpeg、gif、bmp等。
            // width        图片宽度,单位:像素(px)。
            // height       图片高度,单位:像素(px)。
            // colorModel   彩色空间,如palette16、ycbcr等。
            // frameNumber  帧数,gif 图片会返回此项。
            $arr = json_decode(file_get_contents($imgInfoUrl), true);
            $files[$key]['name'] = substr($value['name'], 0, strrpos($value['name'], '.')); //只保留文件名部分,去除文件名后缀
            $files[$key]['width'] = $arr['width']; //图片宽度
            $files[$key]['height'] = $arr['height']; //图片高度
            $files[$key]['create_time'] = time();//创建时间
        }
    }
 
    // 插入数据库
    if ($this->db->insert_batch('photos', $files)) {
        echo '上传成功';
        die;
    } else {
        echo '上传失败';
        die;
    }
}
 
 
复制代码



差不多就这样,因为初次接触,所以难免有不完善的地方,如果大家有什么更好的方法,欢迎探讨。
详细内容请看我的博文:http://caiweiming.com/zai-codeigniter-kuang-jia-zhong-shi-yong-plupload-cha-jian-shang-chuan-dao-qiniu-yun-cun-chu.html
发表于 2016-4-26 11:56:44 | 显示全部楼层
photo.path = res.key; // 保存后的图片名称(含前缀)
发表于 2016-4-26 11:57:15 | 显示全部楼层
photo.path = res.key; // 保存后的图片名称(含前缀) --  请问这个 前缀是在哪儿设置的?
发表于 2016-4-26 11:57:51 | 显示全部楼层
photo.path = res.key; // 保存后的图片名称(含前缀)  

请问这个 前缀是在哪儿设置的?

本版积分规则