PHP的ECSHOP商城的改造成MVC添加商品功能总结

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/blacop/article/details/71191824
PHP的ECSHOP商城的改造成MVC添加商品功能总结
    原始的ECSHOP商城不是MVC的架构,改造成MVC架构.    
admin后台 Platform =back,登录页面进去是index.php,里面是一个框架集frameset,上面是top,html,
左边是menu.html,滚动条drag.html,右边是main.html,都放在back/view下面,
menu.html里面的
的添加商品href的action是
-------------
<ul id="menu-ul">
  <li name="menu" key="02_cat_and_goods" class="explode">
    商品管理        <ul>
          <li class="menu-item"><a target="main-frame" href="goods.php?act=list">商品列表</a></li>
          <li class="menu-item"><a target="main-frame" href="index.php?p=back&c=Goods&a=add">添加新商品</a></li>
-------------
修改后是调用控制器c=Goods,View=add.html,m=GoodsModel,
View=add.html的FORM里面有 添加商品的超链接a href里面 a=insert,控制器c=Goods,样式CSS可以不管,直接用原来的就行。
-------------
back/view/goods_add.html
 <!-- tab body -->
    <div id="tabbody-div">
      <form name="theForm" method="post" action="index.php?p=back&c=Goods&a=insert" enctype="multipart/form-data">

    点击submit按钮后POST提交了表单到 $_POST 数组里面,form表单的action属性是就会自动跳去执行="index.php?p=back&c=Goods&a=insert"

    UPLOAD做成了一个工具类class放在framwork框架的tool目录里面,用作商品图的上传处理。 
    GoodsController会调用UPLOAD.class.php
-------------
back/controller/GoodsController.class.php
---
/**
 * 后台的商品相关操作控制器类
 */
class GoodsController extends PlatformController {
    /**
     * 商品添加表单
     */
    public function addAction() {
        require CURRENT_VIEW_PATH . 'goods_add.html';
    }

    /**
     * 商品插入
     */
    public function insertAction() {
        //收集表单数据
        $data['goods_name'] = $_POST['goods_name'];
        $data['shop_price'] = $_POST['shop_price'];
        $data['goods_desc'] = $_POST['goods_desc'];
        $data['goods_number'] = $_POST['goods_number'];
        //上架
        $data['is_on_sale'] = isset($_POST['is_on_sale']) ? '1' : '0';
        //推荐属性
        $data['goods_promote'] = isset($_POST['goods_promote']) ? implode(',', $_POST['goods_promote']) : '';
        //通过模型插入到数据表
        $m_goods = Factory::M('GoodsModel');
        //根据插入结果,给出提示,并展示
        if ($m_goods->insertGoods($data)) {
            //成功, 跳转到商品列表
            $this->_jump('index.php?p=back&c=Goods&a=list');
        } else {
            //失败,给出错误提示,返回到add添加动作
            $this->_jump('index.php?p=back&c=Goods&a=add', '添加失败:失败原因');
        }
    }

    public function listAction() {
        echo 'Goods:list';
    }
}

-------------
back/model/GoodsModel.class.php
/**
 * 后台 商品表的操作模型
 */
class GoodsModel extends Model {
    protected $_logic_table = 'goods';
    /**
     * 插入商品
     * @param $data array,关联数组字段与值
     * @return bool
     */
    public function insertGoods($data) {
        //先数据校验
        $data['create_admin_id'] = $_SESSION['admin']['admin_id'];
        //插入到goods表
        // 保证数据转义后:
        $escape_data = $this->_escapeStringAll($data);
        $sql = sprintf("INSERT INTO $this->_table VALUES (null, %s, %s, '', %s, %s, %s, %s, %s, %s)", $escape_data['goods_name'], $escape_data['shop_price'], $escape_data['goods_image_ori'], $escape_data['goods_desc'], $escape_data['goods_number'], $escape_data['is_on_sale'], $escape_data['goods_promote'], $escape_data['create_admin_id']);
        //执行
        return $this->_dao->query($sql);
    }
}




展开阅读全文

没有更多推荐了,返回首页