关于 pluplod 插件 结合thinkphp上传图片的功能

看前端代码

<!DOCTYPE html>

<html>

<head>

<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>

<title>Plupload - Queue widget example</title>

<link rel="stylesheet" href="__PUBLIC__/index/plupload/js/jquery.plupload.queue/css/jquery.plupload.queue.css" type="text/css" media="screen" />

</head>

<body style="font: 13px Verdana; background: #eee; color: #333">

<form method="post" action="{:U('Index/Qiniu/form')}" id='f11' enctype="multipart/form-data">

<div style="float: left; margin-right: 20px">

<div id="flash_uploader" style="width: 500px; height: 330px;">请引用plupload文件夹里面的Moxie.swf</div>

</div>

<div id="aaaa"></div>

<input type="submit" value="Send" />

</form>

<script src="__PUBLIC__/index/js/jquery-1.10.1.min.js"></script>

<!--引入核心文件 S-->

<script type="text/javascript" src="__PUBLIC__/index/plupload/js/plupload.full.min.js"></script>

<script type="text/javascript" src="__PUBLIC__/index/plupload/js/jquery.plupload.queue/jquery.plupload.queue.js"></script>

<!--引入核心文件 E-->

<script src="__PUBLIC__/index/plupload/js/i18n/zh_CN.js"></script><!--引入中文包-->

<!-- debug 

<script type="text/javascript" src="__PUBLIC__/plupload/js/moxie.js"></script>

<script type="text/javascript" src="__PUBLIC__/plupload/js/plupload.dev.js"></script>

<script type="text/javascript" src="__PUBLIC__/plupload/js/jquery.plupload.queue/jquery.plupload.queue.js"></script>

-->

<script type="text/javascript">

$(function() {

// Setup flash version

$("#flash_uploader").pluploadQueue({

// General settings

runtimes : 'html5,flash,silverlight,html4',//指定上传方式

url : "{:U('Index/Qiniu/upload')}",//后台url

chunk_size : '4mb',//分片大小

unique_names : true,//文件名是否唯一

multiple:true,

filters : {

max_file_size : '12mb', //最大只能上传1mb的文件

mime_types: [

{title : "Image files", extensions : "jpg,gif,png"}, //限制上传类型

],

prevent_duplicates:true, //是否选取重复的文件

},

//压缩设置

resize: {

width: 100,

height: 100,

crop: true, //是否裁剪图片

quality: 60,

preserve_headers: false//:压缩后是否保留图片的元数据,true为保留,false为不保留,默认为true。

},

init:{

FileUploaded:function(up,file,info)

{

var response = $.parseJSON(info.response);

//console.info(response);//调试信息 打印自己看

//console.info(up);//调试信息 打印自己看

//console.info(file);//调试信息 打印自己看

//console.info(info);//调试信息 打印自己看

if (info.status) {

$('#aaaa').append('文件路径:<input type="hidden" name="fileUrl[]" value="'+response+'"/></br>');

//这块代码很关键 用于当上传完一个文件后 继续显示添加文件和开始上传按钮

if(up.total.uploaded==up.files.length)

{

$(".plupload_buttons").css("display","inline");

$(".plupload_upload_status").css("display","inline");

$(".pluploaded_start").addClass("plupload_disabled");

}

up.disableBrowse(false);

}},

FilesAdded: function (up, files) {

//文件上传数量限制

$.each(up.files, function (i, file) {

//console.info(up.files.length);

if (up.files.length >2) {

up.splice(2, up.files.length-2);

// up.stop();

alert('只能上传两个文件');

return false;

}

});

},

UploadComplete:function(up,files)

{

up.refresh();

},

QueueChanged:function(up)

{

$(".plupload_start").removeClass("plupload_disabled");

}

},

// Flash settings

flash_swf_url : '__PUBLIC__/index/plupload/js/Moxie.swf',

silverlight_xap_url : '__PUBLIC__/index/plupload/js/Moxie.xap'

});

});

</script>

</body>

</html>

 看后端代码

<?php

/**

 * 七牛云储存  测试文件

 * @author Administrator

 *

 */

class QiniuAction extends Action{

public function index(){

$this->display('Plupload');

}

/**

* 上传文件 plupload js插件

*/

public function upload()

{

import('ORG.Net.UploadFile');

$upload = new UploadFile();// 实例化上传类

$rdate=date("Ymd",time()); //文件名

$upload->maxSize = 3145728 ;// 设置附件上传大小 

$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型 

$upload->savePath = C('IMG_UPLOADS').'fg/'.$rdate.'/';// 设置附件上传目录

// 上传文件 

$info = $upload->upload(); 

if(!$info) {

// 上传错误提示错误信息 

$this->error($upload->getError()); 

}else

{

// 上传成功 

echo json_encode($info['file']['savepath'].$info['file']['savename']);

}

}

//后台处理数据

public function form()

{

  dump($_POST);

}

}

?>

我这个代码是结合thinkphp3.1框架,所以使用的时候请注意;

其实这个代码是一个朋友在thinkphp发布过,我只是修改了一下,适应我的框架代码,感谢 梦之翼(http://2262805.blog.51cto.com)