ThinkPHP图片上传_PHP教程
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;
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>?>
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>?>
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>
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>
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>?>
最后图片上传成功,生成两张缩略图:
需要说明的是:
ThinkPHP里自带的图片上传类(UploadFile.class.php) 和图片模型类(Image.class.php),要完整版的ThinkPHP包才有。
没有的话需要在Lib里创建一个文件夹(ORG),然后去官网下载扩展包把这两个文件放到ORG文件夹中。
我的是第二种情况

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

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

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.

Ü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? 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. 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? 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.

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.

Ü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
