PHP.30-TP框架商城应用实例-后台8-商品相册-添加

商品相册【是商品的其他相片】

添加相册需求:

每张图片生成三张缩略图{50*50、350*350、650*650}

1、建表p39_goods_pic{id,pic,sm_pic,mid_pic,big_pic,goods_id

drop table if exists p39_goods_pic;
create table p39_goods_pic(
    id mediumint unsigned not null auto_increment comment ‘Id‘,
    pic varchar(150) not null default ‘‘ comment ‘原图‘,
    sm_pic varchar(150) not null default ‘‘ comment ‘小图‘,
    mid_pic varchar(150) not null default ‘‘ comment ‘中图‘,
    big_pic varchar(150) not null default ‘‘ comment ‘大图‘,
    goods_id mediumint unsigned not null comment ‘商品Id‘,
    primary key(id),
    key goods_id(goods_id)
)engine=InnoDB default charset=utf8 comment ‘商品相册‘;

p39_goods_pic

2、在添加表单的商品相册处制作一个“添加一张”的按钮,通过JS实现点击一次增加一个文本域

//添加一张
        $("#btn_add_pic").click(function(){
            var file = ‘<li><input type="file" name="pic[]" /></li>‘;
            $("#ul_pic_list").append(file);

JS demo

3、在商品模型GoodsModel.class.php/_after_inser()中添加处理商品相册的代码

思路

1.利用已经封装好的函数uploadOne(名称,存放目录,[缩略图尺寸数组]),上传一张图片

function uploadOne($imgName, $dirName, $thumb = array())
    {
        // 上传LOGO
        if(isset($_FILES[$imgName]) && $_FILES[$imgName][‘error‘] == 0)
        {
            $ic = C(‘IMAGE_CONFIG‘);
            $upload = new \Think\Upload(array(
                ‘rootPath‘ => $ic[‘rootPath‘],
                ‘maxSize‘ => $ic[‘maxSize‘],
                ‘exts‘ => $ic[‘exts‘],
            ));// 实例化上传类
            $upload->savePath = $dirName . ‘/‘; // 图片二级目录的名称
            // 上传文件
            // 上传时指定一个要上传的图片的名称,否则会把表单中所有的图片都处理,之后再想其他图片时就再找不到图片了
            $info   =   $upload->upload(array($imgName=>$_FILES[$imgName]));
            if(!$info)
            {
                return array(
                    ‘ok‘ => 0,
                    ‘error‘ => $upload->getError(),
                );
            }
            else
            {
                $ret[‘ok‘] = 1;
                $ret[‘images‘][0] = $logoName = $info[$imgName][‘savepath‘] . $info[$imgName][‘savename‘];
                // 判断是否生成缩略图[$thumb数组存储尺寸]
                if($thumb)
                {
                    $image = new \Think\Image();
                    // 循环生成缩略图
                    foreach ($thumb as $k => $v)
                    {
                        $ret[‘images‘][$k+1] = $info[$imgName][‘savepath‘] . ‘thumb_‘.$k.‘_‘ .$info[$imgName][‘savename‘];
                        // 打开要处理的图片
                        $image->open($ic[‘rootPath‘].$logoName);
                        $image->thumb($v[0], $v[1])->save($ic[‘rootPath‘].$ret[‘images‘][$k+1]);
                    }
                }
                return $ret;
            }
        }
    }

uploadOne()

2、循环每张图片调用uploadOne一个一个处理,处理完插入到相册表中

先观察文件数据的结构,如下:

两种文件,一是商品logo{logo};而是商品相册pic{pic},一维数组logo;二维数组pic

因为商品图片pic是二维数组,而uploaOne只能处理一维数组,类似logo那样的数组结构,因此要转换为一维数组$pics[]

再进行图片处理

//钩子方法_after_insert:添加操作成功后执行
        protected function _after_insert($data, $option)
        {
            /**********商品相册处理********/
            $pics = array();
            //var_dump($_FILES[‘pic‘][‘name‘]);die();
            //二维数组转成一维
            foreach ($_FILES[‘pic‘][‘name‘] as $k => $v)
            {
                $pics[] = array(
                    ‘name‘ => $v,
                    ‘type‘ => $_FILES[‘pic‘][‘type‘][$k],
                    ‘tmp_name‘ => $_FILES[‘pic‘][‘tmp_name‘][$k],
                    ‘error‘ => $_FILES[‘pic‘][‘error‘][$k],
                    ‘size‘ => $_FILES[‘pic‘][‘size‘][$k],
                );
            }
            //var_dump($pics);die();
            $_FILES = $pics;    //把处理好的数组赋给$_FILES,因为uploadOne函数是在$_FILES中获取图片的
            $gpModel = M(‘goods_pic‘);
            //循环每个上传
            foreach ($pics as $k => $v)
            {
                if($v[‘error‘] == 0)
                {
                    $ret = uploadOne($k, ‘Goods‘, array(
                        array(650, 650),
                        array(350, 350),
                        array(50, 50),
                    ));
                    //var_dump($ret);die();
                    if($ret[‘ok‘] == 1)
                    {
                        $gpModel->add(array(
                            ‘pic‘ => $ret[‘images‘][0],
                            ‘big_pic‘ => $ret[‘images‘][1],
                            ‘mid_pic‘ => $ret[‘images‘][2],
                            ‘sm_pic‘ => $ret[‘images‘][3],
                            ‘goods_id‘ => $data[‘id‘],
                        ));
                    }
                }
            }
            /**********会员价格处理********/
            $mp = I(‘post.member_price‘);    //接收post提交过来的会员价格数据
            $mpModel = D(‘member_price‘);
            foreach ($mp as $k => $v)
            {
                $_v = (float)$v;    //强制转为浮点型,以免插入字符等错误数据
                //设置会员价格>0就插入到表中
                if($_v > 0)
                {
                    $mpModel->add(array(
                        ‘price‘ => $_v,
                        ‘level_id‘ => $k,        //级别Id
                        ‘goods_id‘ => $data[‘id‘],
                    ));
                }
            }
        }

_after_insert

注意:批量上传时,uploaOne是处理不了二维数组的,必须转成一维数组,再用foreach循环插入数据库

问题:

1、上传的图片数量在表单看来是没有限制的,倒是在php.ini中限制了post_max_size,所以在商品添加表单还需做点优化,限制用户上传图片的尺寸和数量

2、PHP脚本默认的执行时间是30秒,可能会导致数据处理不完。可根据需求,在表单数据处理前使用set_time_limit()进行设置

时间: 2024-10-27 11:33:47

PHP.30-TP框架商城应用实例-后台8-商品相册-添加的相关文章

PHP.31-TP框架商城应用实例-后台9-商品相册-修改、删除(AJAX)

商品相册图片删除 当商品删除时,把相册中的图片一并从硬盘和数据库中删除,根据商品id[因为每一张商品相片都会生成三张缩略图,所以删除时要将其缩略图一并删除] //钩子方法_before_delete:删除前的操作 protected function _before_delete($option) { $id = $option['where']['id']; //要删除的商品的ID /***********删除商品相片********/ //先查询出原商品相册的路径 $gpModel = M(

PHP.29-TP框架商城应用实例-后台7-商品会员修改-页面优化,多表数据更新

商品表修改功能 1.页面优化,类似添加页面 1 <layout name="layout" /> 2 3 <div class="tab-div"> 4 <div id="tabbar-div"> 5 <p> 6 <span class="tab-front" >通用信息</span> 7 <span class="tab-back&quo

PHP.36-TP框架商城应用实例-后台14-商品管理-商品扩展分类的删除、修改

商品分类删除 1.删除商品时,根据商品id删除扩展分类表数据 商品扩展分类修改 1.在控制器GoodsController.class.php/edit()中根据商品id取出对应的所有扩展分类 2.在修改页面edit.html中显示对应扩展分类foreach,类似添加页面 注:考虑当没有扩展分类时的显示,使用if($gcData) 3.在模型类GoodsModel.class.php/_before_update()中处理扩展分类,先删除原数据,再插入新数据[多对多时,通常的用法] <?php

PHP.43-TP框架商城应用实例-后台16-商品属性3-库存量管理

库存量管理 思想:为商品的每个多选属性设置库存量!!要把多选属性排列组合分别指定库存量!! 效果如下:[由商品已经添加的属性决定] 1.建表goods_number{goods_id,goods_number,goods_str_id[商品属性id]} drop if exists p39_goods_number; create table p39_goods_number ( goods_id mediumint unsigned not null comment '商品Id', goods

PHP.25-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图

添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace Admin\Controller; use Think\Controller; //后台添加商品功能控制器 class GoodsController extends Controller { //显示和处理表单 public function add() { //判断用户是否提交了表单(如果提交了,就

PHP.28-TP框架商城应用实例-后台4-使用Gii生成品牌表的代码

Gii安装[GII适用于商城项目] 将Gii文件夹复到application 是,访问http://xx.com/index.php/gii Gii规则[Gii使用规则与建表规则密切相关] 1.建表字段必须有中文名,则Gii在生成代码时才能识别某字段的中文名是什么: 2.某字段验证规则不能为空:设置该建表字段为not null:一般所有字段都为not null,若不希望生成验证规则,则加上默认值default(默认值可为空): 3.生成上传图片代码:字段名中需包含logo|image|pic|f

PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证

权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,=>增加一个父控制器验证Session 让所有后台的控制器[除了Login控制器之外的]都继承自这个控制器 5.在管理员访问后台的任何一个页面之前先到数据库中查看当前管理员所在的角色是否有权限访问这个页面 在权限模型中增加此检查方法,在父类登录控制器中调用 6.后台左侧只显示当前管理员有权限访问的按钮

PHP.27-TP框架商城应用实例-后台3-商品修改、删除

商品修改{修改页一般与添加页有百分之九十的相似度} create($_POST,Model::MODEL_UPDATE):系统内置的数据操作包括Model::MODEL_INSERT(或者1)和Model::MODEL_UPDATE(或者2),当没有指定的时候,系统根据数据源是否包含主键数据来自动判断,如果存在主键数据,就当成Model::MODEL_UPDATE操作. save():用于更新数据库信息:如果失败返回false,如果成功返回受影响条数 1.控制器GoodsController.c

PHP.39-TP框架商城应用实例-后台16-商品属性2-AJAX添加、删除

 添加商品属性 思路:根据[后台15]类型表{id,type_name}与属性表{id,attr_name,attr_type,attr_option_values,type_id} 1.建表商品属性表p39_goods_attr{id,attr_value,attr_id,goods_id} /********商品属性表[多对多:一个属性可以有多个值,一个商品可以有多个属性,一个属性可以对应多个商品]*******/ drop if exists p39_goods_attr; create