片上传在站点里是非经常常使用的功能.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. Extjs4 RowEditing 的使用和更新方法

    如何灵活快速的掌握RowEditing组件的应用,应大家的要求,今天给大家具体讲下该组件的使用. 1.创建 var rowEditing = Ext.create('Ext.grid.plugin.R ...

  2. python列表和QVariant

    pyqt中.要给QAbstractTableModel的setData函数传递一个list參数: [20,'00:00:19'] 涉及到QVariant和list的转换. 能够使用QVariant类中 ...

  3. SE 2014年4月14日

    一. 概述BGP的特点 BGP协议是一种距离矢量协议,基于TCP的179端口,BGP协议不会动态的学习路由,只能将IGP协议学习到的或者静态路由注入到BGP中,成为BGP路由,BGP路由携带有丰富的路 ...

  4. Android之场景桌面(一)

    声明:转载请务必注明出处,本文代码和主题仅供学习交流,请勿用于商业用途. 引言:最近Android场景桌面开始流行起来了,跟原始的Android桌面相比,场景桌面能逼真的模拟各种自然物体,并且通过点击 ...

  5. poj 3265 Problem Solving dp

    这个题目容易让人误以为是贪心就可以解决了,但是细想一下很容易举出反例. dp[i][j]表示解决了i个问题,最后一个月解决的问题数目. #include <iostream> #inclu ...

  6. [置顶] Guava学习之Multimap

    相信大家对Java中的Map类及其之类有大致的了解,Map类是以键值对的形式来存储元素(Key->Value),但是熟悉Map的人都知道,Map中存储的Key是唯一的.什么意思呢?就是假如我们有 ...

  7. SQL SERVER FOR 多列字符串连接 XML PATH 及 STUFF

    原文:SQL SERVER FOR 多列字符串连接 XML PATH 及 STUFF 本来用 Writer 写一篇关于一列多行合并的博客来的,结果快写完了时候,在一个插入代码时候,崩了,重新打开,居然 ...

  8. xml publisher根据条件显示或隐藏列

     xml publisher根据条件显示或隐藏列 <?if@column:condition? > -- <?end if?> 样例: 依据PROJECT_FLAG标签显示 ...

  9. HibernateReview Day2–Hibernate体系结构

    本文摘自 李刚 著 <Java EE企业应用实战> 现在我们知道了一个概念Hibernate Session,只有处于Session管理下的POJO才具有持久化操作能力.当应用程序对于处于 ...

  10. NSUserDefaults写作和阅读对象定义自己

    需要编写对象必须实现NSCoding protocol Person Class Person.h #import <Foundation/Foundation.h> #import &q ...