Rumah pembangunan bahagian belakang tutorial php ThinkPHP图片上传_PHP教程

ThinkPHP图片上传_PHP教程

Jul 13, 2016 am 10:36 AM
aspnet pengaturcaraan perisian

  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;
Salin selepas log masuk

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>?>
Salin selepas log masuk

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>?>        
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>?>
Salin selepas log masuk

 

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

 

 

需要说明的是:

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

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

我的是第二种情况

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/738519.htmlTechArticleThinkPHP是国内比较流行的轻量级的PHP框架,它在国内流行的一个最主要的因素在于它的说明文档非常健全完善,以及它源码内的注释都是中文...
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Gabungan Vue.js dan ASP.NET menyediakan petua dan cadangan untuk pengoptimuman prestasi dan pengembangan aplikasi web. Gabungan Vue.js dan ASP.NET menyediakan petua dan cadangan untuk pengoptimuman prestasi dan pengembangan aplikasi web. Jul 29, 2023 pm 05:19 PM

Gabungan Vue.js dan ASP.NET menyediakan petua dan cadangan untuk pengoptimuman prestasi dan pengembangan aplikasi web Dengan perkembangan pesat aplikasi web, pengoptimuman prestasi telah menjadi tugas yang sangat diperlukan dan penting untuk pembangun. Sebagai rangka kerja bahagian hadapan yang popular, Vue.js digabungkan dengan ASP.NET boleh membantu kami mencapai pengoptimuman dan pengembangan prestasi yang lebih baik. Artikel ini akan memperkenalkan beberapa petua dan cadangan, serta memberikan beberapa contoh kod. 1. Kurangkan permintaan HTTP Bilangan permintaan HTTP secara langsung mempengaruhi kelajuan pemuatan aplikasi web. lulus

Penggunaan kolam sambungan MySQL dan teknik pengoptimuman dalam program ASP.NET Penggunaan kolam sambungan MySQL dan teknik pengoptimuman dalam program ASP.NET Jun 30, 2023 pm 11:54 PM

Bagaimana untuk menggunakan dan mengoptimumkan kolam sambungan MySQL dengan betul dalam program ASP.NET? Pengenalan: MySQL ialah sistem pengurusan pangkalan data yang digunakan secara meluas yang menampilkan prestasi tinggi, kebolehpercayaan dan kemudahan penggunaan. Dalam pembangunan ASP.NET, menggunakan pangkalan data MySQL untuk penyimpanan data adalah keperluan biasa. Untuk meningkatkan kecekapan dan prestasi sambungan pangkalan data, kami perlu menggunakan dan mengoptimumkan kumpulan sambungan MySQL dengan betul. Artikel ini akan memperkenalkan cara menggunakan dan mengoptimumkan kumpulan sambungan MySQL dengan betul dalam program ASP.NET.

Sepuluh cara AI generatif akan mengubah pembangunan perisian Sepuluh cara AI generatif akan mengubah pembangunan perisian Mar 11, 2024 pm 12:10 PM

Penterjemah |. Disemak oleh Chen Jun |. Pada tahun 1990-an, apabila orang menyebut pengaturcaraan perisian, ia biasanya bermaksud memilih editor, menyemak kod ke dalam pangkalan kod CVS atau SVN, dan kemudian menyusun kod ke dalam fail boleh laku. Persekitaran pembangunan bersepadu (IDE) yang sepadan seperti Eclipse dan Visual Studio boleh menyepadukan pengaturcaraan, pembangunan, dokumentasi, pembinaan, ujian, penggunaan dan langkah-langkah lain ke dalam kitaran hayat pembangunan perisian yang lengkap (SDLC), sekali gus meningkatkan kecekapan pemaju. Dalam tahun-tahun kebelakangan ini, pengkomputeran awan yang popular dan alat automasi DevSecOps telah meningkatkan keupayaan komprehensif pembangun, menjadikannya lebih mudah bagi lebih banyak perusahaan untuk membangun, menggunakan dan menyelenggara aplikasi perisian. Hari ini, AI generatif ialah pembangunan generasi akan datang

Bagaimana untuk menyambung semula ke MySQL dalam program ASP.NET? Bagaimana untuk menyambung semula ke MySQL dalam program ASP.NET? Jun 29, 2023 pm 02:21 PM

Bagaimana untuk menyambung semula ke MySQL dalam program ASP.NET? Dalam pembangunan ASP.NET, adalah sangat biasa untuk menggunakan pangkalan data MySQL. Walau bagaimanapun, disebabkan oleh sebab rangkaian atau pelayan pangkalan data, sambungan pangkalan data kadangkala mungkin terganggu atau tamat masa. Dalam kes ini, untuk memastikan kestabilan dan kebolehpercayaan program, kami perlu mewujudkan semula sambungan selepas sambungan diputuskan. Artikel ini akan memperkenalkan cara menyambung semula sambungan MySQL dalam program ASP.NET. Untuk merujuk ruang nama yang diperlukan terlebih dahulu, rujuknya di kepala fail kod

Gabungan Vue.js dan ASP.NET membolehkan pembangunan dan penggunaan aplikasi peringkat perusahaan Gabungan Vue.js dan ASP.NET membolehkan pembangunan dan penggunaan aplikasi peringkat perusahaan Jul 29, 2023 pm 02:37 PM

Gabungan Vue.js dan ASP.NET membolehkan pembangunan dan penggunaan aplikasi peringkat perusahaan Dalam bidang teknologi Internet yang pesat membangun hari ini, pembangunan dan penggunaan aplikasi peringkat perusahaan telah menjadi semakin penting. Vue.js dan ASP.NET ialah dua teknologi yang digunakan secara meluas dalam pembangunan bahagian hadapan dan belakang. Menggabungkannya boleh membawa banyak kelebihan kepada pembangunan dan penggunaan aplikasi peringkat perusahaan. Artikel ini akan memperkenalkan cara menggunakan Vue.js dan ASP.NET untuk membangunkan dan menggunakan aplikasi peringkat perusahaan melalui contoh kod. Pertama, kita perlu memasang

Bagaimana untuk mengkonfigurasi dan menggunakan kolam sambungan MySQL dengan betul dalam program ASP.NET? Bagaimana untuk mengkonfigurasi dan menggunakan kolam sambungan MySQL dengan betul dalam program ASP.NET? Jun 29, 2023 pm 12:56 PM

Bagaimana untuk mengkonfigurasi dan menggunakan kolam sambungan MySQL dengan betul dalam program ASP.NET? Dengan perkembangan Internet dan peningkatan jumlah data, permintaan untuk capaian pangkalan data dan sambungan juga meningkat. Untuk meningkatkan prestasi dan kestabilan pangkalan data, pengumpulan sambungan telah menjadi teknologi penting. Artikel ini terutamanya memperkenalkan cara mengkonfigurasi dan menggunakan kumpulan sambungan MySQL dengan betul dalam program ASP.NET untuk meningkatkan kecekapan dan kelajuan tindak balas pangkalan data. 1. Konsep dan fungsi penyatuan sambungan adalah teknologi yang menggunakan semula sambungan pangkalan data. Ia digunakan pada permulaan program.

Apakah objek terbina dalam aspnet? Apakah objek terbina dalam aspnet? Nov 21, 2023 pm 02:59 PM

Objek terbina dalam ASP.NET termasuk "Permintaan", "Respons", "Sesi", "Pelayan", "Aplikasi", "HttpContext", "Cache", "Trace", "Cookie" dan "Server.MapPath": 1. Permintaan, menunjukkan permintaan HTTP yang dikeluarkan oleh klien 2. Respons: menunjukkan respons HTTP yang dikembalikan oleh pelayan web kepada pelanggan, dsb.

Konfigurasi yang disyorkan untuk pembangunan ASP.NET menggunakan Visual Studio pada Linux Konfigurasi yang disyorkan untuk pembangunan ASP.NET menggunakan Visual Studio pada Linux Jul 06, 2023 pm 08:45 PM

Gambaran keseluruhan konfigurasi yang disyorkan untuk menggunakan Visual Studio untuk pembangunan ASP.NET pada Linux: Dengan pembangunan perisian sumber terbuka dan populariti sistem pengendalian Linux, semakin ramai pembangun mula membangunkan ASP.NET pada Linux. Sebagai alat pembangunan yang berkuasa, Visual Studio sentiasa menduduki kedudukan dominan pada platform Windows. Artikel ini akan memperkenalkan cara mengkonfigurasi VisualStudio untuk ASP.NE pada Linux

See all articles