Heim Backend-Entwicklung PHP-Tutorial ThinkPHP图片上传_PHP教程

ThinkPHP图片上传_PHP教程

Jul 13, 2016 am 10:36 AM
aspnet Softwareprogrammierung

  ThinkPHP是国内比较流行的轻量级的PHP框架,它在国内流行的一个最主要的因素在于它的说明文档非常健全完善,以及它源码内的注释都是中文的,方便于英语能力较差的程序员学习.

图片上传在网站里是很常用的功能.ThinkPHP里也有自带的图片上传类(UploadFile.class.php) 和图片模型类(Image.class.php)。方便于我们去实现图片上传功能.

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

<span 1</span> CREATE TABLE <span IF</span><span  NOT EXISTS `tp_image` (
</span><span 2</span>   `id` int(11) NOT <span NULL</span> AUTO_INCREMENT,
<span 3</span>   `image` varchar(200) NOT <span NULL</span>,
<span 4</span>   `create_time` int(11) NOT <span NULL</span>,
<span 5</span>   PRIMARY <span KEY</span><span  (`id`)
</span><span 6</span> ) ENGINE=MyISAM  <span DEFAULT</span> CHARSET=utf8;
Nach dem Login kopieren

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

<?<span php
</span><span return</span> <span array</span><span (
        </span>'URL_MODEL'    =>    2, <span //</span><span  如果你的环境不支持PATHINFO 请设置为3</span>
        'DB_TYPE'    =>    'mysql',
        'DB_HOST'    =>    'localhost',
        'DB_NAME'    =>    'thinkphp',
        'DB_USER'    =>    'root',
        'DB_PWD'    =>    '',
        'DB_PORT'    =>    '3306',
        'DB_PREFIX'    =>    'tp_',
        
        'SHOW_PAGE_TRACE' =><span true</span>,        <span //</span><span 显示页面调试明细</span>
        
        'TMPL_PARSE_STRING' =>  <span array</span>( <span //</span><span  地址替换,用_UPLOAD_目录 代替 根目录下的Upload目录</span>
         '__UPLOAD__'    =>  __ROOT__.'/Uploads',<span 
     )</span>,<span 
);
</span>?>
Nach dem Login kopieren

3.添加一个Image模块(名字可以随便取)

<?<span php
    </span><span class</span> ImageAction <span extends</span><span  Action{        
        
        </span><span /*</span><span *
         * 创建index 入口方法
         </span><span */</span>
        <span public</span> <span function</span><span  index(){
            </span><span $image</span>=M('Image'<span );                       
            </span><span $data</span>=<span $image</span>->order('create_time desc')->find();    <span //</span><span 获取最后上传图片</span>
            <span $this</span>->assign('data',<span $data</span><span );
            </span><span $this</span>-><span display();
        }
 
</span>?>        
Nach dem Login kopieren

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

<!DOCTYPE html <span PUBLIC</span> "-//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">
    <span #</span><span img{height:22px; border:#000 2px solid}</span>
    <span #</span><span button{height:30px; width:100px;}</span>
</style>
</head>
<body>
    <div <span class</span>="result" >上传允许文件类型:gif png jpg 图像文件,并生成2张缩略图,其中大图带水印,生成后会删除原图。</div><br>
    <notempty name="data"><img  src="/static/imghw/default1.png"  data-src="http://www.bkjia.com/uploads/allimg/140310/052001C59-0.jpg"  class="lazy" / alt="ThinkPHP图片上传_PHP教程" > <img  src="/static/imghw/default1.png"  data-src="http://www.bkjia.com/uploads/allimg/140310/052001C59-0.jpg"  class="lazy" / alt="ThinkPHP图片上传_PHP教程" ></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>
Nach dem Login kopieren

5.选择图片,点击上传按钮后,会跳到Image模块的upload方法上,Image模块上现在还没有这个方法,于是我们创建它

<?<span php
    </span><span class</span> ImageAction <span extends</span><span  Action{        
        
        </span><span /*</span><span *
         * 创建index 入口方法
         </span><span */</span>
        <span public</span> <span function</span><span  index(){
            </span><span $image</span>=M('Image'<span );                        
            </span><span $data</span>=<span $image</span>->order('create_time desc')->find();    <span //</span><span 获取最后上传图片</span>
            
            <span var_dump</span>(<span $data</span><span );
            </span><span $this</span>->assign('data',<span $data</span><span );
            </span><span $this</span>-><span display();
        } <br />               
        </span><span //</span><span 如果上传的文件不为空,跳转到_upload方法</span>
        <span public</span> <span function</span><span  upload(){        
            </span><span //</span><span 如果不为空</span>
            <span if</span>(!<span empty</span>(<span $_FILES</span><span ))
            {
                </span><span $this</span>-><span _upload();
            }
            
        }</span>
Nach dem Login kopieren

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

<?<span php
    </span><span class</span> ImageAction <span extends</span><span  Action{        
        
        </span><span /*</span><span *
         * 创建index 入口方法
         </span><span */</span>
        <span public</span> <span function</span><span  index(){
            </span><span $image</span>=M('Image'<span );                        
            </span><span $data</span>=<span $image</span>->order('create_time desc')->find();    <span //</span><span 获取最后上传图片</span>
            
            <span var_dump</span>(<span $data</span><span );
            </span><span $this</span>->assign('data',<span $data</span><span );
            </span><span $this</span>-><span display();
        } 
        
        
        </span><span //</span><span 如果上传的文件不为空,跳转到_upload方法</span>
        <span public</span> <span function</span><span  upload(){        
            </span><span //</span><span 如果不为空</span>
            <span if</span>(!<span empty</span>(<span $_FILES</span><span ))
            {
                </span><span $this</span>-><span _upload();
            }
            
        }
        
        
        </span><span /*</span><span **
         * 实现图片上传
         </span><span */</span>
        <span public</span> <span function</span><span  _upload(){
            import(</span>'@.ORG.UploadFile'<span );
            </span><span //</span><span 导入上传类</span>
            <span $upload</span> = <span new</span><span  UploadFile();
            </span><span //</span><span 设置上传文件大小</span>
            <span $upload</span>->maxSize            = 3292200<span ;
            </span><span //</span><span 设置上传文件类型</span>
            <span $upload</span>->allowExts          = <span explode</span>(',', 'jpg,gif,png,jpeg'<span );
            </span><span //</span><span 设置附件上传目录</span>
            <span $upload</span>->savePath           = './Uploads/'<span ;
            </span><span //</span><span 设置需要生成缩略图,仅对图像文件有效</span>
            <span $upload</span>->thumb              = <span true</span><span ;
            </span><span //</span><span  设置引用图片类库包路径</span>
            <span $upload</span>->imageClassPath     = '@.ORG.Image'<span ;
            </span><span //</span><span 设置需要生成缩略图的文件后缀</span>
            <span $upload</span>->thumbPrefix        = 'm_,s_';  <span //</span><span 生产2张缩略图
            //设置缩略图最大宽度</span>
            <span $upload</span>->thumbMaxWidth      = '400,100'<span ;
            </span><span //</span><span 设置缩略图最大高度</span>
            <span $upload</span>->thumbMaxHeight     = '400,100'<span ;
            </span><span //</span><span 设置上传文件规则</span>
            <span $upload</span>->saveRule           = 'uniqid'<span ;
            </span><span //</span><span 删除原图</span>
            <span $upload</span>->thumbRemoveOrigin  = <span true</span><span ;
            
            
            </span><span //</span><span 如果上传不成功</span>
            <span if</span> (!<span $upload</span>-><span upload()) 
            {
                </span><span //</span><span 捕获上传异常</span>
                <span $this</span>->error(<span $upload</span>-><span getErrorMsg());
            } 
            </span><span else</span><span  
            {
                </span><span //</span><span 取得成功上传的文件信息</span>
                <span $uploadList</span> = <span $upload</span>-><span getUploadFileInfo();
                
                
                </span><span //</span><span 导入图片类</span>
                import('@.ORG.Image'<span );                
            
                </span><span //</span><span 给m_缩略图添加水印, Image::water('原文件路径','水印图片地址')</span>
                Image::water(<span $uploadList</span>[0]['savepath'] . 'm_' . <span $uploadList</span>[0]['savename'], APP_PATH.'Tpl/Public/Images/logo.png'<span );
                
                </span><span //</span><span 图片名赋值给 字段image</span>
                <span $_POST</span>['image'] = <span $uploadList</span>[0]['savename'<span ];
            }
            </span><span $model</span>  = M('image'<span );
            </span><span //</span><span 保存当前数据对象</span>
            <span $data</span>['image']          = <span $_POST</span>['image'<span ];
            </span><span $data</span>['create_time']    =<span  NOW_TIME;
            </span><span $list</span>   = <span $model</span>->add(<span $data</span><span );
            </span><span if</span> (<span $list</span> !== <span false</span><span ) 
            {
                </span><span $this</span>->success('上传图片成功!'<span );
            } 
            </span><span else</span><span  
            {
                </span><span $this</span>->error('上传图片失败!'<span );
            }
        }
        
    }
</span>?>
Nach dem Login kopieren

 

最后图片上传成功,生成两张缩略图:

 

 

需要说明的是:

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

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

我的是第二种情况

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/738519.htmlTechArticleThinkPHP是国内比较流行的轻量级的PHP框架,它在国内流行的一个最主要的因素在于它的说明文档非常健全完善,以及它源码内的注释都是中文...
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Die Kombination von Vue.js und ASP.NET liefert Tipps und Anregungen zur Performance-Optimierung und Erweiterung von Webanwendungen. Die Kombination von Vue.js und ASP.NET liefert Tipps und Anregungen zur Performance-Optimierung und Erweiterung von Webanwendungen. Jul 29, 2023 pm 05:19 PM

Die Kombination von Vue.js und ASP.NET liefert Tipps und Vorschläge zur Leistungsoptimierung und Erweiterung von Webanwendungen. Mit der rasanten Entwicklung von Webanwendungen ist die Leistungsoptimierung zu einer unverzichtbaren und wichtigen Aufgabe für Entwickler geworden. Als beliebtes Front-End-Framework kann Vue.js in Kombination mit ASP.NET uns dabei helfen, eine bessere Leistungsoptimierung und -erweiterung zu erreichen. In diesem Artikel werden einige Tipps und Vorschläge vorgestellt sowie einige Codebeispiele bereitgestellt. 1. HTTP-Anfragen reduzieren Die Anzahl der HTTP-Anfragen wirkt sich direkt auf die Ladegeschwindigkeit von Webanwendungen aus. passieren

Nutzung und Optimierungstechniken des MySQL-Verbindungspools in ASP.NET-Programmen Nutzung und Optimierungstechniken des MySQL-Verbindungspools in ASP.NET-Programmen Jun 30, 2023 pm 11:54 PM

Wie verwende und optimiere ich den MySQL-Verbindungspool in ASP.NET-Programmen richtig? Einführung: MySQL ist ein weit verbreitetes Datenbankverwaltungssystem, das sich durch hohe Leistung, Zuverlässigkeit und Benutzerfreundlichkeit auszeichnet. Bei der ASP.NET-Entwicklung ist die Verwendung einer MySQL-Datenbank zur Datenspeicherung eine häufige Anforderung. Um die Effizienz und Leistung von Datenbankverbindungen zu verbessern, müssen wir den MySQL-Verbindungspool korrekt verwenden und optimieren. In diesem Artikel erfahren Sie, wie Sie den MySQL-Verbindungspool in ASP.NET-Programmen korrekt verwenden und optimieren.

Zehn Möglichkeiten, wie generative KI die Softwareentwicklung verändern wird Zehn Möglichkeiten, wie generative KI die Softwareentwicklung verändern wird Mar 11, 2024 pm 12:10 PM

Übersetzer | Rezensiert von Chen Jun | Entsprechende integrierte Entwicklungsumgebungen (IDEs) wie Eclipse und Visual Studio können Programmierung, Entwicklung, Dokumentation, Konstruktion, Test, Bereitstellung und andere Schritte in einen vollständigen Softwareentwicklungslebenszyklus (SDLC) integrieren und so die Arbeit der Entwickler verbessern. In den letzten Jahren haben beliebte Cloud-Computing- und DevSecOps-Automatisierungstools die umfassenden Fähigkeiten von Entwicklern verbessert und es für mehr Unternehmen einfacher gemacht, Softwareanwendungen zu entwickeln, bereitzustellen und zu warten. Heute ist generative KI die Entwicklung der nächsten Generation

Wie kann ich im ASP.NET-Programm erneut eine Verbindung zu MySQL herstellen? Wie kann ich im ASP.NET-Programm erneut eine Verbindung zu MySQL herstellen? Jun 29, 2023 pm 02:21 PM

Wie kann ich im ASP.NET-Programm erneut eine Verbindung zu MySQL herstellen? In der ASP.NET-Entwicklung wird häufig die MySQL-Datenbank verwendet. Aus Gründen des Netzwerks oder des Datenbankservers kann es jedoch manchmal zu Unterbrechungen oder einer Zeitüberschreitung der Datenbankverbindung kommen. In diesem Fall müssen wir die Verbindung wiederherstellen, nachdem die Verbindung getrennt wurde, um die Stabilität und Zuverlässigkeit des Programms sicherzustellen. In diesem Artikel erfahren Sie, wie Sie MySQL-Verbindungen in ASP.NET-Programmen wiederherstellen. Um zunächst auf die erforderlichen Namespaces zu verweisen, verweisen Sie diese am Anfang der Codedatei

Die Kombination von Vue.js und ASP.NET ermöglicht die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene Die Kombination von Vue.js und ASP.NET ermöglicht die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene Jul 29, 2023 pm 02:37 PM

Die Kombination von Vue.js und ASP.NET ermöglicht die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene. Im heutigen sich schnell entwickelnden Bereich der Internettechnologie wird die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene immer wichtiger. Vue.js und ASP.NET sind zwei Technologien, die in der Front-End- und Back-End-Entwicklung weit verbreitet sind. Ihre Kombination kann viele Vorteile für die Entwicklung und Bereitstellung von Anwendungen auf Unternehmensebene bringen. In diesem Artikel wird anhand von Codebeispielen erläutert, wie Sie mit Vue.js und ASP.NET Anwendungen auf Unternehmensebene entwickeln und bereitstellen. Zuerst müssen wir installieren

Wie konfiguriere und verwende ich den MySQL-Verbindungspool im ASP.NET-Programm richtig? Wie konfiguriere und verwende ich den MySQL-Verbindungspool im ASP.NET-Programm richtig? Jun 29, 2023 pm 12:56 PM

Wie konfiguriere und verwende ich den MySQL-Verbindungspool im ASP.NET-Programm richtig? Mit der Entwicklung des Internets und der Zunahme des Datenvolumens steigt auch der Bedarf an Datenbankzugängen und -verbindungen. Um die Leistung und Stabilität der Datenbank zu verbessern, ist Verbindungspooling zu einer wesentlichen Technologie geworden. In diesem Artikel wird hauptsächlich die korrekte Konfiguration und Verwendung des MySQL-Verbindungspools in ASP.NET-Programmen vorgestellt, um die Effizienz und Antwortgeschwindigkeit der Datenbank zu verbessern. 1. Das Konzept und die Funktion des Verbindungspoolings ist eine Technologie, die Datenbankverbindungen wiederverwendet.

Was sind die integrierten Objekte in Aspnet? Was sind die integrierten Objekte in Aspnet? Nov 21, 2023 pm 02:59 PM

Zu den integrierten Objekten in ASP.NET gehören „Request“, „Response“, „Session“, „Server“, „Application“, „HttpContext“, „Cache“, „Trace“, „Cookie“ und „Server.MapPath“: 1. Anfrage, Angabe der vom Client ausgegebenen HTTP-Anfrage; 2. Antwort: Angabe der vom Webserver zurückgegebenen HTTP-Antwort Kunde usw.

Empfohlene Konfiguration für die ASP.NET-Entwicklung mit Visual Studio unter Linux Empfohlene Konfiguration für die ASP.NET-Entwicklung mit Visual Studio unter Linux Jul 06, 2023 pm 08:45 PM

Überblick über die empfohlene Konfiguration für die Verwendung von Visual Studio für die ASP.NET-Entwicklung unter Linux: Mit der Entwicklung von Open-Source-Software und der Popularität des Linux-Betriebssystems beginnen immer mehr Entwickler, ASP.NET unter Linux zu entwickeln. Als leistungsstarkes Entwicklungstool nimmt Visual Studio seit jeher eine dominierende Stellung auf der Windows-Plattform ein. In diesem Artikel wird erläutert, wie Sie VisualStudio für ASP.NE unter Linux konfigurieren

See all articles