08-05更新ThinkPHP+swfupload多图上传实例 经典实用的php多图上传
先上一张图片给大家看看效果,有需要就下载学习。不一定非要在ThinkPHP里,只是我非常喜欢去用ThinkPHP做开发了。
好了。现在咱们需要的东西是,下载一个swfupload.js网上很多,自己百度吧.之前有人加我QQ说我写的博文大部分都是代码,看不懂,我以后写博文也先说明思路,然后开始贴代码分享
整个多图上传的流程
1.写好html代码,包括上传以后显示的效果的html,以及加载swfupload组件.和flash
2.在添加图片以后上传到php里处理上传并且返回上传图片的地址,加载到预览区域里.
3.点击X以后,ajax调用php的方法去删除预览区域的图片.
4.在添加图片和删除预览区域的图片的同时,都会更改一个隐藏域的值,这样在完成整个上传提交表单以后可以把图片的地址保存到数据库.(看需要)
好了。先写html代码吧。(css文件我就不贴了)
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><htmlxmlns="http://www.w3.org/1999/xhtml"><head><metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/><metahttp-equiv="Cache-control"content="private,must-revalidate"/><title>flash无刷新多图片上传</title><scripttype="text/javascript">varpath='__STYLE__';varurl='__URL__';</script><scripttype="text/javascript"src="__STYLE__/js/jquery.js"></script><scripttype="text/javascript"src="__STYLE__/js/swfupload.js"></script><scripttype="text/javascript"src="__STYLE__/js/handlers.js"></script><linkhref="__STYLE__/css/default.css"rel="stylesheet"type="text/css"/><scripttype="text/javascript">varswfu;window.onload=function(){swfu=newSWFUpload({upload_url:"__URL__/uploadImg",post_params:{"PHPSESSID":"<?phpechosession_id();?>"},file_size_limit:"2MB",file_types:"*.jpg;*.png;*.gif;*.bmp",file_types_description:"JPGImages",file_upload_limit:"100",file_queue_error_handler:fileQueueError,file_dialog_complete_handler:fileDialogComplete,upload_progress_handler:uploadProgress,upload_error_handler:uploadError,upload_success_handler:uploadSuccess,upload_complete_handler:uploadComplete,button_image_url:"__STYLE__/images/upload.png",button_placeholder_id:"spanButtonPlaceholder",button_width:113,button_height:33,button_text:'',button_text_style:'.spanButtonPlaceholder{font-family:Helvetica,Arial,sans-serif;font-size:14pt;}',button_text_top_padding:0,button_text_left_padding:0,button_window_mode:SWFUpload.WINDOW_MODE.TRANSPARENT,button_cursor:SWFUpload.CURSOR.HAND,flash_url:"__STYLE__/swf/swfupload.swf",custom_settings:{upload_target:"divFileProgressContainer"},debug:false});};</script></head><body><formaction="__URL__/s"method="post"><divstyle="width:610px;height:auto;border:1pxsolid#e1e1e1;font-size:12px;padding:10px;"><spanid="spanButtonPlaceholder"></span><divid="divFileProgressContainer"></div><divid="thumbnails"><ulid="pic_list"style="margin:5px;"></ul><divstyle="clear:both;"></div></div></div><inputtype="hidden"name="s"id=""value=""/><inputtype="submit"value="提交"/></form></body></html>
详细说一下swfupload的配置项
upload_url是上传图片处理的php地址
file_size_limit上传大小限制
file_upload_limit限制用户一次性最多上传多少张图片,0为不限制
file_queue_error_handler
file_dialog_complete_handler添加文件上传选择框关闭以后执行的方法
upload_error_handler文件上传错误的时候执行的方法
upload_success_handler文件上传成功以后执行的方法
upload_complete_handler文件上传完成以后执行的方法
debug:false想研究swfupload的可以把这个设置为true,调试模式
接下来就是上传图片的php代码,我就用的TP的上传类,简单,容易懂
functionuploadImg(){import('ORG.Net.UploadFile');$upload=newUploadFile();//实例化上传类$upload->maxSize=3145728;//设置附件上传大小$upload->allowExts=array('jpg','gif','png','jpeg');//设置附件上传类型$savepath='./uploads/'.date('Ymd').'/';if(!file_exists($savepath)){mkdir($savepath);}$upload->savePath=$savepath;//设置附件上传目录if(!$upload->upload()){//上传错误提示错误信息$this->error($upload->getErrorMsg());}else{//上传成功获取上传文件信息$info=$upload->getUploadFileInfo();}print_r(J(__ROOT__.'/'.$info[0]['savepath'].'/'.$info[0]['savename']));}
上传成功以后,echo或者print_r输出地址,因为他用的是ajax的方式。
预览区域设置的代码
functionuploadSuccess(file,serverData){addImage(serverData);var$svalue=$('form>input[name=s]').val();if($svalue==''){$('form>input[name=s]').val(serverData);}else{$('form>input[name=s]').val($svalue+"|"+serverData);}}functionaddImage(src){varnewElement="<li><imgclass='content'src='"+src+"'style=\"width:100px;height:100px;\"><imgclass='button'src="+window.path+"/images/fancy_close.png></li>";$("#pic_list").append(newElement);$("img.button").last().bind("click",del);}
serverData就是在php里返回的图片地址,在返回以后,直接调用addImage方法,将地址加载到一个ul里。同时更新隐藏域里的值
删除图片设置
vardel=function(){//varfid=$(this).parent().prevAll().length+1;varsrc=$(this).siblings('img').attr('src');var$svalue=$('form>input[name=s]').val();$.ajax({type:"GET",//访问WebService使用Post方式请求url:window.url+"/del",//调用WebService的地址和方法名称组合---WsURL/方法名data:"src="+src,success:function(data){var$val=$svalue.replace(data,'');$('form>input[name=s]').val($val);}});$(this).parent().remove();}
ajax方式,提交到php方式,成功则更新隐藏域里的val,并且销毁元素。
functiondel(){$src=str_replace(__ROOT__.'/','',str_replace('//','/',$_GET['src']));if(file_exists($src)){unlink($src);}print_r($_GET['src']);exit();}
删除的方法很简单,就是删除ajax提交过来的地址的文件,并且返回删除的地址,ajax会处理并且自动更新隐藏域的val
整个ThinkPHP+swfupload上传图片的方法就完了。很简单。ThinkPHP+swfupload多图上传实例下载链接: http://pan.baidu.com/s/1dD8avap 密码: 7idq
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。