片上传在站点里是非经常常使用的功能.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. svn简介与使用

    本文简单介绍windows下svn服务器与客户端软件的简单应用. 其中,svn服务器用于储存和管理代码,相当与文本服务器的作用(多版本控制等功能),同时分配用户代码的访问与使用权限. 客户端软件 用于 ...

  2. 自编Ps教程—我的ps图片赞赏

    上篇讲述了主要的ps概念和操作,这里不再讲述了,主要的操作学好了,其它的都简单,下面我会把我闲暇时间天马行空的小作品上穿,以供大家闲暇时间或者工作累了的时候赞赏! 以后还会在这里上传哦!喜欢就收藏吧! ...

  3. C++ Preprosessor import

    #import Attributes Provides links to attributes used with the #import directive. Microsoft Specific ...

  4. poj1094Sorting It All Out

    主题链接: 啊哈哈,选我 题目: Sorting It All Out Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 268 ...

  5. 求1e11以内的素数

    有两种做法,一种是打表,另一种是直接求. 打表 将1e11每隔len(len=2000w)个数字统计一下该区间内素数的个数,比如cnt[1] 表示[1,len]以内有多少个素数,cnt[2]表示[le ...

  6. Javascript异步数据的同步处理方法

    数据处理方法封装 var DataWatch=(function(){ var gWatch={},cursor= 0,callback_key = 'callback',gMap={}; var c ...

  7. JAVA的class打包成dll

    一.将已经编译后的java中Class文件进行打包:打包命令JAR 如:将某目录下的所有class文件夹全部进行打包处理: 使用的命令:jar cvf test.jar -C com/ . //注意这 ...

  8. iosclient暑期“动画屋“活动项目总结

        入职实习的这个公司,第一天就分配了任务.从零開始写一个网页.之前尽管了解一些前端知识.但从头开写还是遇到了非常多问题,互联网公司讲求效率,有deadline还是比較有紧迫感的,与在实验室放羊状 ...

  9. hdu4670(树上点分治+状态压缩)

    树上路径的f(u,v)=路径上所有点的乘积. 树上每个点的权值都是由给定的k个素数组合而成的,如果f(u,v)是立方数,那么就说明f(u,v)是可行的方案. 问有多少种可行的方案. f(u,v)可是用 ...

  10. Javascript语言精粹之正则表达式知识整理

    Javascript语言精粹之正则表达式知识整理 1.正则表达式思维导图 2.正则表达式常用示例 2.1 移除所有标签,只留下innerText var html = "<p>& ...