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文件夹中。
我的是第二种情况

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La combinaison de Vue.js et ASP.NET fournit des conseils et des suggestions pour l'optimisation des performances et l'expansion des applications Web. Avec le développement rapide des applications Web, l'optimisation des performances est devenue une tâche indispensable et importante pour les développeurs. En tant que framework frontal populaire, Vue.js combiné à ASP.NET peut nous aider à obtenir une meilleure optimisation et expansion des performances. Cet article présentera quelques conseils et suggestions, et fournira quelques exemples de code. 1. Réduire les requêtes HTTP Le nombre de requêtes HTTP affecte directement la vitesse de chargement des applications Web. passer

Comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET ? Introduction : MySQL est un système de gestion de bases de données largement utilisé qui offre des performances élevées, une fiabilité et une facilité d'utilisation. Dans le développement ASP.NET, l'utilisation d'une base de données MySQL pour le stockage des données est une exigence courante. Afin d'améliorer l'efficacité et les performances des connexions aux bases de données, nous devons utiliser et optimiser correctement le pool de connexions MySQL. Cet article explique comment utiliser et optimiser correctement le pool de connexions MySQL dans les programmes ASP.NET.

Traducteur | Révisé par Chen Jun | Chonglou Dans les années 1990, lorsque les gens parlaient de programmation logicielle, cela signifiait généralement choisir un éditeur, vérifier le code dans la base de code CVS ou SVN, puis compiler le code dans un fichier exécutable. Les environnements de développement intégrés (IDE) correspondants tels qu'Eclipse et Visual Studio peuvent intégrer la programmation, le développement, la documentation, la construction, les tests, le déploiement et d'autres étapes dans un cycle de vie complet de développement logiciel (SDLC), améliorant ainsi l'efficacité du travail des développeurs. Ces dernières années, les outils populaires de cloud computing et d'automatisation DevSecOps ont amélioré les capacités complètes des développeurs, permettant ainsi à un plus grand nombre d'entreprises de développer, de déployer et de maintenir plus facilement des applications logicielles. Aujourd’hui, l’IA générative est le développement de la prochaine génération

Comment se reconnecter à MySQL dans le programme ASP.NET ? Dans le développement ASP.NET, il est très courant d'utiliser la base de données MySQL. Cependant, pour des raisons de réseau ou de serveur de base de données, la connexion à la base de données peut parfois être interrompue ou expirer. Dans ce cas, afin de garantir la stabilité et la fiabilité du programme, nous devons rétablir la connexion après la déconnexion de la connexion. Cet article explique comment reconnecter les connexions MySQL dans les programmes ASP.NET. Pour référencer d'abord les espaces de noms nécessaires, référencez-les en tête du fichier de code

La combinaison de Vue.js et d'ASP.NET permet le développement et le déploiement d'applications au niveau de l'entreprise Dans le domaine technologique Internet en développement rapide actuel, le développement et le déploiement d'applications au niveau de l'entreprise sont devenus de plus en plus importants. Vue.js et ASP.NET sont deux technologies largement utilisées dans le développement front-end et back-end. Leur combinaison peut apporter de nombreux avantages au développement et au déploiement d'applications au niveau de l'entreprise. Cet article expliquera comment utiliser Vue.js et ASP.NET pour développer et déployer des applications au niveau de l'entreprise à travers des exemples de code. Tout d'abord, nous devons installer

Comment configurer et utiliser correctement le pool de connexions MySQL dans le programme ASP.NET ? Avec le développement d’Internet et l’augmentation du volume de données, la demande d’accès et de connexions aux bases de données augmente également. Afin d’améliorer les performances et la stabilité de la base de données, le pooling de connexions est devenu une technologie incontournable. Cet article explique principalement comment configurer et utiliser correctement le pool de connexions MySQL dans les programmes ASP.NET pour améliorer l'efficacité et la vitesse de réponse de la base de données. 1. Le concept et la fonction du pooling de connexions Le pooling de connexions est une technologie qui réutilise les connexions de bases de données. Elle est utilisée au début du programme.

Comment utiliser correctement et optimiser les performances des transactions du pool de connexions MySQL dans les programmes ASP.NET ? Dans les programmes ASP.NET, les transactions de base de données constituent une partie très importante. Les transactions garantissent la cohérence et l'intégrité de la base de données tout en offrant de meilleures performances. Lors de l'utilisation d'une base de données MySQL, il est essentiel d'utiliser un pool de connexions pour gérer les ressources de connexion et optimiser les performances. Tout d’abord, comprenons brièvement le concept de pool de connexions MySQL. Le pool de connexions est un pool tampon d'un groupe de connexions en pré-initialisant un certain nombre de connexions.

Les objets intégrés dans ASP.NET incluent "Request", "Response", "Session", "Server", "Application", "HttpContext", "Cache", "Trace", "Cookie" et "Server.MapPath" : 1. Requête, indiquant la requête HTTP émise par le client 2. Réponse : indiquant la réponse HTTP renvoyée par le serveur web au client ; client, etc
