ThinkPHP 3.2.3集成uploadify上传控件
uploadify控件有一个坑爹的问题,就是文件上传时会session丢失,官方解释http://www.uploadify.com/documentation/uploadify/using-sessions-with-uploadify/,通过formData属性解决。
前端代码
<input type="file" name="file_upload" id="file_upload" />
$('#file_upload').uploadify({
'auto' : false,//关闭自动上传
'removeTimeout' : 1,//文件队列上传完成1秒后删除
'swf' : basePath+'resource/js/source/uploadify/uploadify.swf',
'uploader' : basePath+'home/file/fileUploadOper.html',
'method' : 'post',//方法,服务端可以用$_POST数组获取数据
'buttonText' : '选择图片',//设置按钮文本
'multi' : true,//允许同时上传多张图片
'uploadLimit' : 10,//一次最多只允许上传10张图片
'fileTypeDesc' : 'Image Files',//只允许上传图像
'fileTypeExts' : '*.gif; *.jpg; *.png; *.jpeg',//限制允许上传的图片后缀
'fileSizeLimit' : '10MB',//限制上传的图片不得超过200KB
'onUploadSuccess' : function(file, data, response){
data = data.substring(0,data.indexOf("}")+1);
var obj = JSON.parse(data);
if(obj.type){
alertWindow("info","信息",obj.msg);
}else{
alertWindow("error","错误",obj.msg);
}
},
'onQueueComplete' : function(queueData) {}
});
$('#upload').click(function(){
var formData = {};
formData['did'] = document.getElementById('did').value;
formData['session'] = $('#session_id').val();
//$('#file_upload').uploadify('settings', 'formData', {'did':document.getElementById('did').value});
$('#file_upload').uploadify('settings', 'formData', formData);
$('#file_upload').uploadify('upload','*');
});
$('#cancel').click(function(){
$('#file_upload').uploadify('cancel','*');
});
通过formData将sessionid传递到后台
后端代码
//接受动态传值
$did = $_POST['did'];
session_id($_POST['session']);
session_start();
//获取目录
$dir = M('Dir');
$dirs = $dir->where("did=$did")->select();
if(count($dirs)>0){
$d = $dirs[0];
$realpath = $d['realpath'];
//得到上传的临时文件流
$tempFile = $_FILES['Filedata']['tmp_name'];
//允许的文件后缀
//$fileTypes = array('jpg','jpeg','gif','png');
//得到文件原名
$fileName = $_FILES["Filedata"]["name"];
$names = explode('.',$fileName);
$newFlieName = create_guid().'.'.$names[1];
if(is_dir($realpath)){
if (move_uploaded_file($tempFile, $realpath.'/'.$newFlieName)){
//$user = session('user');
$user = $_SESSION['user'];
//生成数据库数据
$file = M('File');
$file->filename = $fileName;
$file->realpath = $realpath.'/'.$newFlieName;
$file->realname = $newFlieName;
$file->path = $d['dpath'].'/'.$newFlieName;
$file->did = $did;
$file->createuid = $user['uid'];
$file->updateuid = $user['uid'];
$file->createtime = time();
$file->updatetime = $file->createtime;
if($file->add()){
$result = '{"type":true,"msg":"'.$fileName.'上传成功。"}';
}else{
$result = '{"type":false,"msg":"'.$fileName.'上传失败,生成数据库记录时失败。"}';
}
}else{
$result = '{"type":false,"msg":"'.$fileName.'上传失败。"}';
}
}else{
$result = '{"type":false,"msg":"文档目录不存在,上传失败。"}';
}
}else{
$result = '{"type":false,"msg":"文档目录不存在,上传失败。"}';
}
echo $result;
使用session_id(),session_start()方法,后面通过$_FILES获取文件流进行文件写入操作。
ThinkPHP 3.2.3集成uploadify上传控件的更多相关文章
- 文件上传~Uploadify上传控件~续(多文件上传)
对于Uploadify文件上传之前已经讲过一次(文件上传~Uploadify上传控件),只不过没有涉及到多文件的上传,这回主要说一下多个文件的上传,首先,我们要清楚一个概念,多文件上传前端Upload ...
- uploadify上传控件中文的乱码解决办法
uploadify上传控件中文的乱码解决办法 网站用的gb2312的编码,用uploadify上传控件上传中文时在IE能部分成功,FF,Chrome则完全失败,查找了一天原因,结果发现是页面编码问题, ...
- 使用uploadify上传控件无法进入后台问题分析
分别在.net mvc 和java struts2中使用到 uploadify上传 文件,遇到同样的问题,选中文件上传后,文件无法上传,打上断点后发现没有进入后台. 逐步断点发现 项目共同点是加入了 ...
- 解决Uploadify上传控件加载导致的GET 404 Not Found问题
今天在项目发用到Uploadify上传, 发现在打开页面时会有一多余的请求,由于路由没有设置这个,导致404错误,能搜索查到以下解决的方法 <Uploadify v3 bug. Unecessa ...
- 文件上传~Uploadify上传控件
对于文件上传来说,有很多种实现方式,如传统的表单方式,现在流行的flash方式,甚至还有纯JS方式,之所以有这些方式来实现文件上传,我想主要原因是因为,传统的上传对于大文件支持不够,因为它是单线程同步 ...
- uploadify上传控件使用
uploadify是JQuery的一个上传插件,实现的效果非常不错,并且带进度显示,我将给大家演示如何使用uploadify进行图片上传, 1.点我下载http://www.uploadify.com ...
- ASP.NET jquery.uploadify上传控件中文乱码解决办法(转)
原文地址:http://blog.csdn.net/ningxi_/article/details/6234725 在一般处理程序上加上这几句话: context.Response.ContentTy ...
- jquery文件上传控件 Uploadify
(转自 http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html) 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...
- 使用Uploadify(UploadiFive)多文件上传控件遇到的坑
最近项目中需要实现多文件上传功能,于是结合需求最终选择了Uploadify这一款控件来实现.相比其他控件,Uploadify具有简洁的界面,功能API基本可以解决大多数需求,又是基于jquery的,配 ...
随机推荐
- $('div','li'),$('div , li'),$('div li')的区别
要搞清楚$('div','li') 和 $('div , li') 和 $('div li') 区别: $('div','li'):是$(子,父),是从父节点里找子,而不是找li外面的div $('d ...
- ExtJs中gridpanel分组后组名排序
/** * 定义降序的groupingStore */ var DescGroupingStore = Ext.extend(Ext.data.GroupingStore, { groupDir : ...
- 优雅的处理Android数据库升级的问题
原始完成于:2015-04-27 19:28:22 提供一种思路,优雅的处理Android数据库升级的问题,直接上代码: 1 package com.example.databaseissuetest ...
- iOS iPad开发之UIPopoverController的使用
1. 什么是UIPopoverController? 是iPad开发中常见的一种控制器(在iphone上不允许使用) 跟其他控制器不一样的是,它直接继承自NSObject,并非继承自UIViewCon ...
- iOS开发网络请求——大文件的多线程断点下载
iOS开发中网络请求技术已经是移动app必备技术,而网络中文件传输就是其中重点了.网络文件传输对移动客户端而言主要分为文件的上传和下载.作为开发者从技术角度会将文件分为小文件和大文件.小文件因为文件大 ...
- ubuntu下安装svn服务器
sudo apt-get install apache2 sudo apt-get install subversion sudo apt-get install libapache2-svn 其次, ...
- Python学习路程day8
Socket语法及相关 socket概念 A network socket is an endpoint of a connection across a computer network. Toda ...
- android技巧(三)屏幕适配
屏幕适配策略: 1.控件使用wrap_content.match_parent控制某些视图组件的宽度和高度,而不是硬编码的尺寸. “wrap_content”系统就会将视图的宽度或高度设置成所需的最小 ...
- EF学习笔记——通用增删改查方案
http://blog.csdn.net/leftfist/article/details/25005307 我刚接触EF未久,还不知道它有什么强大之处,但看上去,EF提供了一般的增删改查功能.以往用 ...
- Jquery选择器之基本选择器
id选择器 共同点: text:代表标签之间的文本值 返回值:均为列表 根据给定的ID值匹配一个标签元素,如果id值中有元字符(如 !"#$%&'()*+,./:;<=> ...