Codeigniter实现多文件上传并创建多个缩略图
发布:smiling 来源: PHP粉丝网 添加日期:2021-02-18 15:27:20 浏览: 评论:0
这篇文章主要介绍了Codeigniter实现多文件上传并创建多个缩略图,需要的朋友可以参考下。
该程序可以实现:
1.同时上传5张图片
2.同时生成两种尺寸的缩略图
3.保存到mysql
controllers:upload.php文件:
- <?php
- class Upload extends Controller {
- function go() {
- if(isset($_POST['go'])) {
- //初始化
- $config['upload_path'] = 'album/source';
- $config['allowed_types'] = 'gif|jpg|png|bmp|jpeg';
- $config['encrypt_name'] = TRUE;
- $config['remove_spaces'] = TRUE;
- $config['max_size'] = '0';
- $config['max_width'] = '0';
- $config['max_height'] = '0';
- $this->load->library('upload', $config);
- //170*170图片
- $configThumb = array();
- $configThumb['image_library'] = 'gd2';
- $configThumb['source_image'] = '';
- $configThumb['create_thumb'] = TRUE;
- $configThumb['maintain_ratio'] = TRUE; //保持图片比例
- $configThumb['new_image'] = 'album/thumb';
- $configThumb['width'] = 170;
- $configThumb['height'] = 170;
- //600*600图片
- $configLarge = array();
- $configLarge['image_library'] = 'gd2';
- $configLarge['source_image'] = '';
- $configLarge['create_thumb'] = TRUE;
- $configLarge['maintain_ratio'] = TRUE; //保持图片比例
- $configLarge['new_image'] = 'album/large';
- $configLarge['width'] = 600;
- $configLarge['height'] = 600;
- $this->load->library('image_lib');
- for($i = 1; $i < 6; $i++) {
- $upload = $this->upload->do_upload('image'.$i);
- if($upload === FALSE) continue;
- $data = $this->upload->data();//返回上传文件的所有相关信息的数组
- $uid = $this->session->userdata('uid');
- $uploadedFiles[$i] = $data;
- if($data['is_image'] == 1) {
- //初始化170*170
- $configThumb['source_image'] = $data['full_path']; //文件路径带文件名
- $this->image_lib->initialize($configThumb);
- $this->image_lib->resize();
- //初始化600*600
- $configLarge['source_image'] = $data['full_path']; //文件路径带文件名
- $this->image_lib->initialize($configLarge);
- $this->image_lib->resize();
- }
- //插入图片信息到album表,插入的文件名为source目录文件名
- $picture = array(
- 'filename' => $data['file_name'],
- 'albumID' => $this->uri->segment(4,0),
- 'uid' => $this->session->userdata('uid'),
- 'dateline' => time(),
- 'describe' => '',
- 'click' => 0
- );
- $this->load->model('album_model');
- $this->album_model->AddPic($picture);
- $picture = array();
- }
- }
- /* 转出 */
- $albumID = $this->uri->segment(4);
- $backurl = site_url() . 'photo/editpic/album/' .$albumID;
- $this->session->set_flashdata('msg','图片上传成功.');
- redirect($backurl,'refresh');
- }
- }
views:new_pic.view文件:
- <form method="post" action="<?php echo site_url() ?>photo/upload/go/<?php echo $albumID ?>" enctype="multipart/form-data">
- <input type="file" name="image1" class="files"/><br />
- <input type="file" name="image2" class="files"/><br />
- <input type="file" name="image3" class="files"/><br />
- <input type="file" name="image4" class="files"/><br />
- <input type="file" name="image5" class="files"/><br />
- <br />
- <p><input type="submit" name="go" value="上传照片" class="button" /></p>
- </form>
此外需要注意:
1.要一次上传几个文件,修改表单和控制器中循环部分的参数就好。
2.album\\source 是上传后原图目录 large和thumb分别是两次执行$this->image_lib->resize();后存放缩略图的目录
3.缩略图文件名如需和album\\source目录一致,请添加参数 $config['thumb_marker'] = '';
4.$picture这部分数组是保存到数据库的东西,可以不用管了。
Tags: Codeigniter 创建多个缩略图
相关文章
- ·CodeIgniter3.0+框架自定义异常处理的方法介绍(2020-02-08)
- ·解决Codeigniter不能上传rar和zip压缩包问题(2020-10-19)
- ·CodeIgniter框架中_remap()使用方法2例(2020-10-20)
- ·CI(CodeIgniter)框架中的增删改查操作(2021-02-11)
- ·CodeIgniter启用缓存和清除缓存的方法(2021-02-13)
- ·让CodeIgniter数据库缓存自动过期的处理的方法(2021-02-13)
- ·Codeigniter生成Excel文档的简单方法(2021-02-13)
- ·Codeigniter+PHPExcel实现导出数据到Excel文件(2021-02-13)
- ·Codeigniter实现智能裁剪图片的方法(2021-02-13)
- ·Codeigniter整合Tank Auth权限类库详解(2021-02-18)
- ·新浪SAE云平台下使用codeigniter的数据库配置(2021-02-18)
- ·Codeigniter实现处理用户登录验证后的URL跳转(2021-02-18)
- ·让codeigniter与swfupload整合的最佳解决方案(2021-02-18)
- ·让CodeIgniter的ellipsize()支持中文截断的方法(2021-02-18)
- ·CodeIgniter框架过滤HTML危险代码(2021-02-18)
- ·Codeigniter上传图片出现“You did not select a file to upload”错误解决办法(2021-02-18)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)