php Action server端

<?php





/*

 * To change this template, choose Tools | Templates

 * and open the template in the editor.

 */





/**

 * Description of UploadAction

 *

 * @author hxwj

 */

class UploadAction extends CommonAction{

    public function _initialize(){

        //此处为解决Uploadify在火狐下出现http 302错误 又一次设置SESSION

        $session_name = session_name();

        if (isset($_POST[$session_name])) {

            session_id($_POST[$session_name]);

            session_start();

        }

    }

    public function upload(){

                import("ORG.Net.UploadFile");

                //导入上传类

                if($_FILES){

                    $upload = new UploadFile();

                    //设置上传文件大小

                    $upload->maxSize = 204800;

                    //设置上传文件类型

                    $upload->allowExts  = array('jpg', 'gif', 'png', 'jpeg');

                    //设置附件上传文件夹

                    $upload->thumb = true;

                    $upload->thumbPrefix = 'm_';  //生产2张缩略图

                    //设置缩略图最大宽度

                    $upload->thumbMaxWidth = '400,100';

                    //设置缩略图最大高度

                    $upload->thumbMaxHeight = '400,100';

                    $upload->savePath = './Uploads/shunongjj/';

                    //设置须要生成缩略图,仅对图像文件有效





                    // 设置引用图片类库包路径

                    //删除原图

                    //$upload->thumbRemoveOrigin = true;

                    if (!$upload->upload()) {

                        //捕获上传异常

                        //$this->error($upload->getErrorMsg());

                        $data['status']='0';

                        $this->ajaxReturn($data,'json');

                    } else {

                        //取得成功上传的文件信息

                        $info =  $upload->getUploadFileInfo();

                        $imgpath = '/Uploads/shunongjj/'.$info[0]['savename'];

                        $data['picurl'] = $imgpath;

                        $data['status']='100';

                        $this->ajaxReturn($data,'json');

                    }

                }

    }

    /*

     * 无缩略图

     */

     public function upload_wsl(){

                import("ORG.Net.UploadFile");

                //导入上传类

                if($_FILES){

                    $upload = new UploadFile();

                    //设置上传文件大小

                    $upload->maxSize = 204800;

                    //设置上传文件类型

                    $upload->allowExts  = array('jpg', 'gif', 'png', 'jpeg');

                    //设置附件上传文件夹

                    $upload->savePath = './Uploads/shunongjj/';

                    //设置须要生成缩略图,仅对图像文件有效





                    // 设置引用图片类库包路径

                    //删除原图

                    //$upload->thumbRemoveOrigin = true;

                    if (!$upload->upload()) {

                        //捕获上传异常

                       //$this->error($upload->getErrorMsg());

                        $data['status']='0';

                        return false;

                       //  $this->ajaxReturn("","上传失败","");

                    } else {

                        //取得成功上传的文件信息

                        $info =  $upload->getUploadFileInfo();

                        return $imgpath = '/Uploads/shunongjj/'.$info[0]['savename'];

                    }

                }

    }

    /*

     * 公司轮换首页图片

     */

     public function upload_index(){

                import("ORG.Net.UploadFile");

                //导入上传类

                if($_FILES){

                    $upload = new UploadFile();

                    //设置上传文件大小

                    $upload->maxSize = 204800;

                    //设置上传文件类型

                    $upload->allowExts  = array('jpg', 'gif', 'png', 'jpeg');

                    //设置附件上传文件夹

                    $upload->savePath = './Uploads/shunongjj/';

                    //设置须要生成缩略图,仅对图像文件有效





                    // 设置引用图片类库包路径

                    //删除原图

                    //$upload->thumbRemoveOrigin = true;

                     if (!$upload->upload()) {

                        //捕获上传异常

                        //$this->error($upload->getErrorMsg());

                        $data['status']='0';

                        $this->ajaxReturn($data,'json');

                    } else {

                        //取得成功上传的文件信息

                        $info =  $upload->getUploadFileInfo();

                        $imgpath = '/Uploads/shunongjj/'.$info[0]['savename'];

                        $data['picurl'] = $imgpath;

                        $data['status']='100';

                        $this->ajaxReturn($data,'json');

                    }

                }

    }

}





?>

模板  tpl  端

html

<input  id="file_upload" name="file_upload" type="file" />(图片上传规范:176*107)

js

<script src="__PUBLIC__/uploadify/jquery.uploadify.min.js" type="text/javascript"></script>

<link rel="stylesheet" type="text/css" href="__PUBLIC__/uploadify/uploadify.css"/>

/**

                 * uploadify插件上产图片

                 */

                $("#file_upload").uploadify({

                    //指定swf文件

                    'swf': '__PUBLIC__/uploadify/uploadify.swf',

                    //后台处理的页面

                    'uploader': '{:U("Upload/upload")}',

                    //button显示的文字

                    'buttonText': '上传图片',

                    //显示的高度和宽度,默认 height 30;width 120

                    //'height': 15,

                    //'width': 80,

                    //上传文件的类型  默觉得全部文件    'All Files'  ;  '*.*'

                    //在浏览窗体底部的文件类型下拉菜单中显示的文本

                    'fileTypeDesc': 'Image Files',

                    //同意上传的文件后缀

                    'fileTypeExts': '*.gif; *.jpg; *.png',

                    //发送给后台的其它參数通过formData指定

                    //'formData': { 'someKey': 'someValue', 'someOtherKey': 1 },

                    //上传文件页面中,你想要用来作为文件队列的元素的id, 默觉得false  自己主动生成,  不带#

                    //'queueID': 'fileQueue',

                    //选择文件后自己主动上传

                    'auto': true,

                    //设置为true将同意多文件上传

                    'onUploadSuccess': function(file, data, response){

    var data = $.parseJSON(data);

                       if(data.status==100) {

                         $("#img_show").html("<img src='"+data.picurl+"'/>");

                         $("#img_url").val(data.picurl);

                       }else{

                         alert("上传失败,可能是您上传的图片大小不符合规范,请重试!");

                       }

    }

               });

            });

基于thinkphp的uploadify上传图功能的更多相关文章

  1. MVC 4 结合jquery.uploadify 上传实例

    前言:由于今天公司源代码服务瘫痪,没法编写代码,利用这个有限的时间,做了一个小小的 基于MVC的图片上传demo,貌似近些年来MVC十分火爆,相关的demo也数不胜数,小弟就在这里打着MVC的旗子,狐 ...

  2. uploadify 上传文件插件

    今天在项目中要用到文件上传功能时,想借助Jquery方式来实现,于是想到用uploadify插件来实现.不经意间在网上看到了一遍关于这个插件的用法,写的很好.在这里就分享给大家,希望对大家有帮助.以下 ...

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

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

  4. 【javascript】html5中使用canvas编写头像上传截取功能

    [javascript]html5中使用canvas编写头像上传截取功能 本人对canvas很是喜欢,于是想仿照新浪微博头像上传功能(前端使用canvas) 本程序目前在谷歌浏览器和火狐浏览器测试可用 ...

  5. JavaWeb实现文件上传下载功能实例解析

    转:http://www.cnblogs.com/xdp-gacl/p/4200090.html JavaWeb实现文件上传下载功能实例解析 在Web应用系统开发中,文件上传和下载功能是非常常用的功能 ...

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

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

  7. Thinkphp拖拽上传文件-使用webuploader插件(自己改动了一些地方)——分片上传

    html页面: <!DOCTYPE html> <html class="js cssanimations"> <head> <meta  ...

  8. Python基于Python实现批量上传文件或目录到不同的Linux服务器

    基于Python实现批量上传文件或目录到不同的Linux服务器   by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...

  9. [转]kindeditor隐藏上传图片框网络图片或本地上传的功能

    原文地址:http://www.lingchenliang.com/post/154.html kindeditor富文本编辑器点击上传图片按钮,在弹出的窗口中去掉上传网络图片的功能,只留下本地上传, ...

随机推荐

  1. Arduino当avr开发板

    原理并不复杂,因为arduino本来就是avr+一堆的库,找个能编译出hex的工具下载到板子就行. 但实际做起来还是碰到很多问题. 先是尝试eclipse+avr plugin 编译时出现make: ...

  2. MVC3 分页Helper

    利用mvc3实现分页效果.效果图如下: 直接拷代码: 首页添加一个Helper的类(命名空间为System.Web.Mvc;). public static HtmlString ShowPageNa ...

  3. In-System Debugger for 8051 Devices(ISD 8051单片机在线调试器)

    此文档包含了最新版本的说明及最近的更新特别是对 ISD51 的说明(用户手册没有此说明) Keil Software,Inc and Keil Elektronik GmbH保留所有此文件中涉及的信息 ...

  4. poj 3259 (Bellman_Ford判断负环)

    题意:John的农场里n块地,m条路连接两块地,k个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts.我们的任务是知道会不会在从某块地出发后又回来,看到了离开之前的自己. 思路:虫洞 ...

  5. 高德地图API

    这周计划: 周一 早上 (高德地图API) 中午写(IFE PART ONE) 下午(高德地图API) 下班(IFE PART ONE)

  6. Cocos2d—X游戏开发之CCTableView详解(十一)

    本来很早就想写关于CCTableView的文章,但是在基本功能实现之后呢,项目需求增加导致对这个控件的研究必须更加深入一点. 好的,现在开始介绍一下这个控件,在Cocos2d—X引擎中,这是一个仿制i ...

  7. CXF 的IP拦截

    非常久没有写技术文档了,今天 记录下Webserver的Ip限制吧 需求是:webserver接口能在内网訪问,可是測试平台的webserver要能够在外网訪问,这样就有了一点差别, 这个实现的比較简 ...

  8. xcode UILabel创建和隐藏

    // 创建label UILabel *label = [[UILabel alloc] init]; // 设置显示的文字 label.text = @"Hello world!Hello ...

  9. HTML系列(六):划分文档结构

    常见的网页结构布局是酱紫的,真是美美哒^O^: 一.添加基本标题h1~h6(没什么好说的): 二.标题分组hgroup <hgroup>用来将标题和子标题进行分组.如果一篇文章articl ...

  10. JavaScript引用类型之Object类型

    在JavaScript中大多数的引用类型都是Object的实例,Object类型也是使用最多的类型! 创建Object类型实例的方式有两种,下面分别来分析一下: (1)第一种是使用new操作符后跟Ob ...