片上传在站点里是非经常常使用的功能.ThinkPHP里也有自带的图片上传类(UploadFile.class.php) 和图片模型类(Image.class.php)。方便于我们去实现图片上传功能,以下是实现方法

1.我们首先须要创建一个表

复制代码代码例如以下:


CREATE TABLE IF NOT EXISTS `tp_image` (

  `id` int(11) NOT NULL AUTO_INCREMENT,

  `image` varchar(200) NOT NULL,

  `create_time` int(11) NOT NULL,

  PRIMARY KEY (`id`)

) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

2.然后再conf文件中加入配置(最后一段配置是可选的,仅仅是为了方便统一管理URL路径)

复制代码代码例如以下:


<?php

return array(

        'URL_MODEL'    =>    2, // 假设你的环境不支持PATHINFO 请设置为3

        'DB_TYPE'    =>    'mysql',

        'DB_HOST'    =>    'localhost',

        'DB_NAME'    =>    'thinkphp',

        'DB_USER'    =>    'root',

        'DB_PWD'    =>    '',

        'DB_PORT'    =>    '3306',

        'DB_PREFIX'    =>    'tp_',



        'SHOW_PAGE_TRACE' =>true,        //显示页面调试明细



        'TMPL_PARSE_STRING' =>  array( // 地址替换,用_UPLOAD_文件夹 取代 根文件夹下的Upload文件夹

         '__UPLOAD__'    =>  __ROOT__.'/Uploads',

     ),

);

?>

3.加入一个Image模块(名字能够随便取)

复制代码代码例如以下:


<?php

    class ImageAction extends Action{        



        /**

         * 创建index 入口方法

         */

        public function index(){

            $image=M('Image');                       

            $data=$image->order('create_time desc')->find();    //获取最后上传图片

            $this->assign('data',$data);

            $this->display();

        } 

?

>

4.创建对应index视图文件(index.html)

复制代码代码例如以下:


<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

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

<title>Insert title here</title>

<style type="text/css">

    #img{height:22px; border:#000 2px solid}

    #button{height:30px; width:100px;}

</style>

</head>

<body>

    <div class="result" >上传同意文件类型:gif png jpg 图像文件,并生成2张缩略图,当中大图带水印,生成后会删除原图。</div><br>

    <notempty name="data"><img src="__UPLOAD__/m_{$data.image}" /> <img src="__UPLOAD__/s_{$data.image}" /></notempty>

    <form action="__URL__/upload" method="post" enctype="multipart/form-data">

        <input type="file" name="image" id="img"/>

        <input type="submit" value="上传" id="button"> 

    </form>

</body>

</html>

5.选择图片,点击上传button后,会跳到Image模块的upload方法上。Image模块上如今还没有这种方法,于是我们创建它

复制代码代码例如以下:


<?

php

    class ImageAction extends Action{        



        /**

         * 创建index 入口方法

         */

        public function index(){

            $image=M('Image');                        

            $data=$image->order('create_time desc')->find();    //获取最后上传图片



            var_dump($data);

            $this->assign('data',$data);

            $this->display();

        } 



        //假设上传的文件不为空,跳转到_upload方法

        public function upload(){        

            //假设不为空

            if(!empty($_FILES))

            {

                $this->_upload();

            }



        }

6.假设提交的不是NULL,则跳到_upload方法上,此方法实现图片上传的功能

复制代码代码例如以下:


<?

php

    class ImageAction extends Action{        



        /**

         * 创建index 入口方法

         */

        public function index(){

            $image=M('Image');                        

            $data=$image->order('create_time desc')->find();    //获取最后上传图片



            var_dump($data);

            $this->assign('data',$data);

            $this->display();

        } 



        

        //假设上传的文件不为空,跳转到_upload方法

        public function upload(){        

            //假设不为空

            if(!empty($_FILES))

            {

                $this->_upload();

            }



        }



        

        /***

         * 实现图片上传

         */

        public function _upload(){

            import('@.ORG.UploadFile');

            //导入上传类

            $upload = new UploadFile();

            //设置上传文件大小

            $upload->maxSize            = 3292200;

            //设置上传文件类型

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

            //设置附件上传文件夹

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

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

            $upload->thumb              = true;

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

            $upload->imageClassPath     = '@.ORG.Image';

            //设置须要生成缩略图的文件后缀

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

            //设置缩略图最大宽度

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

            //设置缩略图最大高度

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

            //设置上传文件规则

            $upload->saveRule           = 'uniqid';

            //删除原图

            $upload->thumbRemoveOrigin  = true;



            

            //假设上传不成功

            if (!$upload->upload()) 

            {

                //捕获上传异常

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

            } 

            else 

            {

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

                $uploadList = $upload->getUploadFileInfo();



                

                //导入图片类

                import('@.ORG.Image');                



                //给m_缩略图加入水印, Image::water('原文件路径','水印图片地址')

                Image::water($uploadList[0]['savepath'] . 'm_' . $uploadList[0]['savename'], APP_PATH.'Tpl/Public/Images/logo.png');



                //图片名赋值给 字段image

                $_POST['image'] = $uploadList[0]['savename'];

            }

            $model  = M('image');

            //保存当前数据对象

            $data['image']          = $_POST['image'];

            $data['create_time']    = NOW_TIME;

            $list   = $model->add($data);

            if ($list !== false) 

            {

                $this->success('上传图片成功!');

            } 

            else 

            {

                $this->error('上传图片失败!');

            }

        }        

    }

?>

上传成功生成两张缩略图

须要说明的是:

ThinkPHP里自带的图片上传类(UploadFile.class.php) 和图片模型类(Image.class.php),要完整版的ThinkPHP包才有。

没有的话须要在Lib里创建一个目录(ORG),然后去官网下载扩展包把这两个文件放到ORG目录中。

我是另一种情况

版权声明:本文博主原创文章,博客,未经同意,不得转载。

thinkphp达到UploadFile.class.php图片上传功能的更多相关文章

  1. H5 利用vue实现图片上传功能。

    H5的上传图片如何实现呢? 以下是我用vue实现的图片上传功能,仅供参考. <!DOCTYPE html> <html> <head> <meta chars ...

  2. 前端丨如何使用 tcb-js-sdk 实现图片上传功能

    前言 tcb-js-sdk 让开发者可以在网页端使用 JavaScript 代码服务访问云开发的服务,以轻松构建自己的公众号页面或者独立的网站等 Web 服务.本文将以实现图片上传功能为例,介绍 tc ...

  3. Spring+SpringMVC+MyBatis+easyUI整合优化篇(七)图片上传功能

    日常啰嗦 前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(六)easyUI与富文本编辑器UEditor整合>讲了富文本编辑器UEditor的整合与使用 ...

  4. PHP语言学习之php做图片上传功能

    本文主要向大家介绍了PHP语言学习之php做图片上传功能,通过具体的内容向大家展示,希望对大家学习php语言有所帮助. 今天来做一个图片上传功能的插件,首先做一个html文件:text.php < ...

  5. [Ting's笔记Day8]活用套件carrierwave gem:(3)Deploy图片上传功能到Heroku网站

    前情提要: 身为Ruby新手村民,创造稳定且持续的学习步调很重要,我用的方法就是一周在IT邦写三篇笔记,希望藉由把笔记和遇到的bug记录下来的过程,能帮助到未来想用Ruby on Rails架站的新手 ...

  6. 给DEDECMS广告管理中增加图片上传功能

    dedecms的广告管理功能稍微有点次,本文就是在dedecms广告管理原有的基础上增加广告图片上传功能. 安装方法,对应自己的dedecms版本下载对应的编码然后解压把里面的文件放在后台目录覆盖即可 ...

  7. vue 图片上传功能

    这次做了vue页面的图片上传功能,不带裁剪功能的! 首先是html代码,在input框上添加change事件,如下:   <ul class="clearfix">   ...

  8. thinkphp微信开发之jssdk图片上传并下载到本地服务器

    public function test2(){ $Weixin = new \Weixin\Controller\BaseController(); $this->assign('signPa ...

  9. Thinkphp整合阿里云OSS图片上传实例

    Thinkphp3.2整合阿里云OSS图片上传实例,图片上传至OSS可减少服务器压力,节省宽带,安全又稳定,阿里云OSS对于做负载均衡非常方便,不用传到各个服务器了 首先引入阿里云OSS类库 < ...

随机推荐

  1. C编译: 使用gdb调试

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! gdb是the GNU Debugger的简称.它是一款UNIX平台的调试器(de ...

  2. random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客

    random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客 random_shuffle (stl算法)打乱顺序 2012-03-31 10:39:11|  分类: 算法 | ...

  3. poj2245Lotto(最基础的dfs)

    题目链接: 啊哈哈,点我点我 思路:最開始画好搜索状态,然后找好结束条件,最好预推断当前找到的个数和能够找到的是否大于6就可以.. 题目: Lotto Time Limit: 1000MS   Mem ...

  4. xcode6 iOS sdk8.1隐藏系统状态栏

    在代码项目(uzplayer)从iOS6升级到iOS8之后,头发如今视频播放器有.系统状态栏后面的背景: 这样就会导致有的时候按下Donebutton,或者拖滑块没有效果 所以,我们须要想个办法.把这 ...

  5. 在C#或者SWT上跨进程访问SWT控件的问题

    可能为了进程安全,无论是C#的Form还是Eclipse的SWT,都不允许跨进程访问控件. 通俗一点说就是: A进程创建了控件Widget,若想在B进程中访问控件Widget就会报错,必须在创建Wid ...

  6. hdu5124(树状数组+离散化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5124 题意:有n条线段,求被覆盖到次数最多的点的次数 分析: 1.可以转化成求前缀和最大的问题:将区间 ...

  7. SurfaceView的一个小应用:开发示波器

    SurfaceView与普通View还有一个重要区别:View的绘图必须在UI线程中进行,但SurfaceView不存在这个问题,因为它是由SurfaceHolder来完成的.所以对于View组件,如 ...

  8. JavaScript模板引擎

    JavaScript模板引擎实例应用   在之前的一篇名为<移动端基于HTML模板和JSON数据的JavaScript交互>的文章中,我向大家说明了为什么要使用JavaScript模板以及 ...

  9. python面向对象具体解释(上)

    创建类 Python 类使用 class 关键字来创建.简单的类的声明能够是关键字后紧跟类名: class ClassName(bases): 'class documentation string' ...

  10. ZTESoft 持续集成 编年史 之 持续集成探索---平台选择

    2012 年 7.8 月份,我们逐渐了解了持续集成的概念,同时我们家庭作坊的dailybuild方式不断爆出各种问题,并且已经无法满足日益增长的各种需求. 我们开始探索持续集成的不同实现方式,首先我们 ...