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上传控件的更多相关文章

  1. 文件上传~Uploadify上传控件~续(多文件上传)

    对于Uploadify文件上传之前已经讲过一次(文件上传~Uploadify上传控件),只不过没有涉及到多文件的上传,这回主要说一下多个文件的上传,首先,我们要清楚一个概念,多文件上传前端Upload ...

  2. uploadify上传控件中文的乱码解决办法

    uploadify上传控件中文的乱码解决办法 网站用的gb2312的编码,用uploadify上传控件上传中文时在IE能部分成功,FF,Chrome则完全失败,查找了一天原因,结果发现是页面编码问题, ...

  3. 使用uploadify上传控件无法进入后台问题分析

    分别在.net mvc 和java struts2中使用到 uploadify上传 文件,遇到同样的问题,选中文件上传后,文件无法上传,打上断点后发现没有进入后台. 逐步断点发现 项目共同点是加入了 ...

  4. 解决Uploadify上传控件加载导致的GET 404 Not Found问题

    今天在项目发用到Uploadify上传, 发现在打开页面时会有一多余的请求,由于路由没有设置这个,导致404错误,能搜索查到以下解决的方法 <Uploadify v3 bug. Unecessa ...

  5. 文件上传~Uploadify上传控件

    对于文件上传来说,有很多种实现方式,如传统的表单方式,现在流行的flash方式,甚至还有纯JS方式,之所以有这些方式来实现文件上传,我想主要原因是因为,传统的上传对于大文件支持不够,因为它是单线程同步 ...

  6. uploadify上传控件使用

    uploadify是JQuery的一个上传插件,实现的效果非常不错,并且带进度显示,我将给大家演示如何使用uploadify进行图片上传, 1.点我下载http://www.uploadify.com ...

  7. ASP.NET jquery.uploadify上传控件中文乱码解决办法(转)

    原文地址:http://blog.csdn.net/ningxi_/article/details/6234725 在一般处理程序上加上这几句话: context.Response.ContentTy ...

  8. jquery文件上传控件 Uploadify

    (转自 http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html) 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...

  9. 使用Uploadify(UploadiFive)多文件上传控件遇到的坑

    最近项目中需要实现多文件上传功能,于是结合需求最终选择了Uploadify这一款控件来实现.相比其他控件,Uploadify具有简洁的界面,功能API基本可以解决大多数需求,又是基于jquery的,配 ...

随机推荐

  1. SVN - 忽略已经提交的文件

    1.在本地删除要忽略的文件 2.与资源库同步,提交删除的文件 3.忽略文件

  2. 黑马程序员——OC语言Foundation框架 NSArray NSSet NSDictionary\NSMutableDictionary

    Java培训.Android培训.iOS培训..Net培训.期待与您交流! (以下内容是对黑马苹果入学视频的个人知识点总结) (一) NSNumber 将各种基本数据类型包装成NSNumber对象 @ ...

  3. iOS移动下上传图片失败解决 (上传多图,带其他参数)

    项目中有一个主要的功能,就是上传图片,结结果移动真的是很奇怪,WiFi,联通,电信都没有问题的情况下,居然在移动下不行,真的是很头疼.不过好在最后是解决了 项目的网络请求我是采用ASIHttpRequ ...

  4. Spark源码学习1.1——DAGScheduler.scala

    本文以Spark1.1.0版本为基础. 经过前一段时间的学习,基本上能够对Spark的工作流程有一个了解,但是具体的细节还是需要阅读源码,而且后续的科研过程中也肯定要修改源码的,所以最近开始Spark ...

  5. Jdk内置性能测试工具的介绍

    (一) JConsole JConsole使用JVM的可扩展性Java管理扩展(JMX)工具来提供关于运行于Java平台的应用程序的性能和资源消耗的信息. 在J2SE 5.0软件中,你需要启动使用-D ...

  6. UIkit框架之UIPickerView

    1.继承链:UIview:UIResponder:NSObject 2.获取uipicker view的属性 (1)@property(nonatomic, readonly) NSIntegernu ...

  7. JSP应用程序(自定义错误页面)

    一.编写 1.index.jsp <%@page contentType="text/html" pageEncoding="UTF-8"%> &l ...

  8. ubuntu14.04 键盘错位小问题

    分享一个ubuntu14.04里的小问题,不知道有没有人跟我一样悲催 问题: 键盘错位了,@和"两个符合正好颠倒,~#这几个也错乱了,~符号跑到了|上,#跑到了shift+|上,这个问题在敲 ...

  9. 【转】15个无比华丽的HTML5/CSS3动画应用

    原文转自:http://www.html5cn.org/article-7089-1.html 前几天,HTML5标准已经尘埃落定,未来的Web将会是由HTML5主导,当然作为开发者对这一喜讯更为动心 ...

  10. [原创]cocos2d-x研习录-第二阶 概念类之节点类(CCNode)

    节点类CCNode在基本概念中并不存在,它是为了建立基本概念之间的关联关系而抽象出来的中间辅助类.这个类在Cocos2D-x中极为重要,它为概念类之间搭建了一座宏伟的桥梁.它的继承关系图如下:     ...