diff --git a/admin_v3.sql b/admin_v3.sql index 813b0704b..52b6a5b5c 100644 --- a/admin_v3.sql +++ b/admin_v3.sql @@ -1,25 +1,135 @@ /* Navicat MySQL Data Transfer -Source Server : ctolog.com -Source Server Version : 50559 -Source Host : ctolog.com:3306 +Source Server : server.cuci.cc +Source Server Version : 50558 +Source Host : server.cuci.cc:3306 Source Database : admin_v3 Target Server Type : MYSQL -Target Server Version : 50559 +Target Server Version : 50558 File Encoding : 65001 -Date: 2018-03-23 17:07:39 +Date: 2018-05-04 11:40:19 */ SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- --- Table structure for goods +-- Table structure for store_express -- ---------------------------- -DROP TABLE IF EXISTS `goods`; -CREATE TABLE `goods` ( +DROP TABLE IF EXISTS `store_express`; +CREATE TABLE `store_express` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `express_title` varchar(50) DEFAULT '' COMMENT '快递公司名称', + `express_code` varchar(50) DEFAULT '' COMMENT '快递公司代码', + `express_desc` text COMMENT '快递公司描述', + `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.有效)', + `sort` bigint(20) unsigned DEFAULT '0' COMMENT '排序', + `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) +) ENGINE=InnoDB AUTO_INCREMENT=95 DEFAULT CHARSET=utf8 COMMENT='商城快递配置'; + +-- ---------------------------- +-- Records of store_express +-- ---------------------------- +INSERT INTO `store_express` VALUES ('5', 'AAE全球专递', 'aae', '顺丰快递公司', '0', '0', '0', '2017-09-12 11:53:40'); +INSERT INTO `store_express` VALUES ('6', '安捷快递', 'anjie', '', '0', '0', '0', '2017-09-13 15:27:26'); +INSERT INTO `store_express` VALUES ('7', '安信达快递', 'anxindakuaixi', null, '0', '0', '0', '2017-09-13 16:05:19'); +INSERT INTO `store_express` VALUES ('8', '彪记快递', 'biaojikuaidi', null, '0', '0', '0', '2017-09-13 16:05:26'); +INSERT INTO `store_express` VALUES ('9', 'BHT', 'bht', '', '0', '0', '0', '2017-09-13 16:05:37'); +INSERT INTO `store_express` VALUES ('10', '百福东方国际物流', 'baifudongfang', null, '0', '0', '0', '2017-09-13 16:05:41'); +INSERT INTO `store_express` VALUES ('11', '中国东方(COE)', 'coe', null, '0', '0', '0', '2017-09-13 16:05:48'); +INSERT INTO `store_express` VALUES ('12', '长宇物流', 'changyuwuliu', null, '0', '0', '0', '2017-09-13 16:05:58'); +INSERT INTO `store_express` VALUES ('13', '大田物流', 'datianwuliu', null, '0', '0', '0', '2017-09-13 16:06:06'); +INSERT INTO `store_express` VALUES ('14', '德邦物流', 'debangwuliu', null, '1', '1', '0', '2017-09-13 16:06:14'); +INSERT INTO `store_express` VALUES ('15', 'DHL', 'dhl', null, '0', '0', '0', '2017-09-13 16:06:24'); +INSERT INTO `store_express` VALUES ('16', 'DPEX', 'dpex', null, '0', '0', '0', '2017-09-13 16:06:29'); +INSERT INTO `store_express` VALUES ('17', 'd速快递', 'dsukuaidi', null, '0', '0', '0', '2017-09-13 16:06:34'); +INSERT INTO `store_express` VALUES ('18', '递四方', 'disifang', null, '0', '0', '0', '2017-09-13 16:06:40'); +INSERT INTO `store_express` VALUES ('19', 'EMS快递', 'ems', '', '1', '0', '0', '2017-09-13 16:06:47'); +INSERT INTO `store_express` VALUES ('20', 'FEDEX(国外)', 'fedex', null, '0', '0', '0', '2017-09-13 16:06:56'); +INSERT INTO `store_express` VALUES ('21', '飞康达物流', 'feikangda', null, '0', '0', '0', '2017-09-13 16:07:03'); +INSERT INTO `store_express` VALUES ('22', '凤凰快递', 'fenghuangkuaidi', null, '0', '0', '0', '2017-09-13 16:07:10'); +INSERT INTO `store_express` VALUES ('23', '飞快达', 'feikuaida', null, '0', '0', '0', '2017-09-13 16:07:16'); +INSERT INTO `store_express` VALUES ('24', '国通快递', 'guotongkuaidi', null, '0', '0', '0', '2017-09-13 16:07:27'); +INSERT INTO `store_express` VALUES ('25', '港中能达物流', 'ganzhongnengda', null, '0', '0', '0', '2017-09-13 16:07:33'); +INSERT INTO `store_express` VALUES ('26', '广东邮政物流', 'guangdongyouzhengwuliu', null, '0', '0', '0', '2017-09-13 16:08:22'); +INSERT INTO `store_express` VALUES ('27', '共速达', 'gongsuda', null, '0', '0', '0', '2017-09-13 16:08:48'); +INSERT INTO `store_express` VALUES ('28', '汇通快运', 'huitongkuaidi', null, '0', '0', '0', '2017-09-13 16:08:56'); +INSERT INTO `store_express` VALUES ('29', '恒路物流', 'hengluwuliu', null, '0', '0', '0', '2017-09-13 16:09:02'); +INSERT INTO `store_express` VALUES ('30', '华夏龙物流', 'huaxialongwuliu', null, '0', '0', '0', '2017-09-13 16:09:12'); +INSERT INTO `store_express` VALUES ('31', '海红', 'haihongwangsong', null, '0', '0', '0', '2017-09-13 16:09:20'); +INSERT INTO `store_express` VALUES ('32', '海外环球', 'haiwaihuanqiu', null, '0', '0', '0', '2017-09-13 16:09:27'); +INSERT INTO `store_express` VALUES ('33', '佳怡物流', 'jiayiwuliu', null, '0', '0', '0', '2017-09-13 16:09:35'); +INSERT INTO `store_express` VALUES ('34', '京广速递', 'jinguangsudikuaijian', null, '0', '0', '0', '2017-09-13 16:09:42'); +INSERT INTO `store_express` VALUES ('35', '急先达', 'jixianda', null, '0', '0', '0', '2017-09-13 16:09:49'); +INSERT INTO `store_express` VALUES ('36', '佳吉物流', 'jjwl', null, '0', '0', '0', '2017-09-13 16:10:01'); +INSERT INTO `store_express` VALUES ('37', '加运美物流', 'jymwl', null, '0', '0', '0', '2017-09-13 16:10:13'); +INSERT INTO `store_express` VALUES ('38', '金大物流', 'jindawuliu', null, '0', '0', '0', '2017-09-13 16:10:22'); +INSERT INTO `store_express` VALUES ('39', '嘉里大通', 'jialidatong', null, '0', '0', '0', '2017-09-13 16:10:33'); +INSERT INTO `store_express` VALUES ('40', '晋越快递', 'jykd', null, '0', '0', '0', '2017-09-13 16:10:40'); +INSERT INTO `store_express` VALUES ('41', '快捷速递', 'kuaijiesudi', null, '0', '0', '0', '2017-09-13 16:10:49'); +INSERT INTO `store_express` VALUES ('42', '联邦快递(国内)', 'lianb', null, '0', '0', '0', '2017-09-13 16:10:58'); +INSERT INTO `store_express` VALUES ('43', '联昊通物流', 'lianhaowuliu', null, '0', '0', '0', '2017-09-13 16:11:07'); +INSERT INTO `store_express` VALUES ('44', '龙邦物流', 'longbanwuliu', null, '0', '0', '0', '2017-09-13 16:11:15'); +INSERT INTO `store_express` VALUES ('45', '立即送', 'lijisong', null, '0', '0', '0', '2017-09-13 16:11:25'); +INSERT INTO `store_express` VALUES ('46', '乐捷递', 'lejiedi', null, '0', '0', '0', '2017-09-13 16:11:36'); +INSERT INTO `store_express` VALUES ('47', '民航快递', 'minghangkuaidi', null, '0', '0', '0', '2017-09-13 16:11:45'); +INSERT INTO `store_express` VALUES ('48', '美国快递', 'meiguokuaidi', null, '0', '0', '0', '2017-09-13 16:11:53'); +INSERT INTO `store_express` VALUES ('49', '门对门', 'menduimen', null, '0', '0', '0', '2017-09-13 16:12:01'); +INSERT INTO `store_express` VALUES ('50', 'OCS', 'ocs', null, '0', '0', '0', '2017-09-13 16:12:10'); +INSERT INTO `store_express` VALUES ('51', '配思货运', 'peisihuoyunkuaidi', null, '0', '0', '0', '2017-09-13 16:12:18'); +INSERT INTO `store_express` VALUES ('52', '全晨快递', 'quanchenkuaidi', null, '0', '0', '0', '2017-09-13 16:12:26'); +INSERT INTO `store_express` VALUES ('53', '全峰快递', 'quanfengkuaidi', null, '0', '0', '0', '2017-09-13 16:12:34'); +INSERT INTO `store_express` VALUES ('54', '全际通物流', 'quanjitong', null, '0', '0', '0', '2017-09-13 16:12:41'); +INSERT INTO `store_express` VALUES ('55', '全日通快递', 'quanritongkuaidi', null, '0', '0', '0', '2017-09-13 16:12:49'); +INSERT INTO `store_express` VALUES ('56', '全一快递', 'quanyikuaidi', null, '0', '0', '0', '2017-09-13 16:12:56'); +INSERT INTO `store_express` VALUES ('57', '如风达', 'rufengda', null, '0', '0', '0', '2017-09-13 16:13:03'); +INSERT INTO `store_express` VALUES ('58', '三态速递', 'santaisudi', null, '0', '0', '0', '2017-09-13 16:13:15'); +INSERT INTO `store_express` VALUES ('59', '盛辉物流', 'shenghuiwuliu', null, '0', '0', '0', '2017-09-13 16:13:22'); +INSERT INTO `store_express` VALUES ('60', '申通', 'shentong', null, '0', '0', '0', '2017-09-13 16:13:34'); +INSERT INTO `store_express` VALUES ('61', '顺丰', 'shunfeng', '', '1', '0', '0', '2017-09-13 16:13:41'); +INSERT INTO `store_express` VALUES ('62', '速尔物流', 'sue', null, '0', '0', '0', '2017-09-13 16:13:48'); +INSERT INTO `store_express` VALUES ('63', '盛丰物流', 'shengfeng', null, '0', '0', '0', '2017-09-13 16:13:55'); +INSERT INTO `store_express` VALUES ('64', '赛澳递', 'saiaodi', null, '0', '0', '0', '2017-09-13 16:14:02'); +INSERT INTO `store_express` VALUES ('65', '天地华宇', 'tiandihuayu', null, '0', '0', '0', '2017-09-13 16:14:11'); +INSERT INTO `store_express` VALUES ('66', '天天快递', 'tiantian', null, '0', '0', '0', '2017-09-13 16:14:19'); +INSERT INTO `store_express` VALUES ('67', 'TNT', 'tnt', null, '0', '0', '0', '2017-09-13 16:14:26'); +INSERT INTO `store_express` VALUES ('68', 'UPS', 'ups', null, '0', '0', '0', '2017-09-13 16:14:29'); +INSERT INTO `store_express` VALUES ('69', '万家物流', 'wanjiawuliu', null, '0', '0', '0', '2017-09-13 16:14:37'); +INSERT INTO `store_express` VALUES ('70', '文捷航空速递', 'wenjiesudi', null, '0', '0', '0', '2017-09-13 16:14:46'); +INSERT INTO `store_express` VALUES ('71', '伍圆', 'wuyuan', null, '0', '0', '0', '2017-09-13 16:14:52'); +INSERT INTO `store_express` VALUES ('72', '万象物流', 'wxwl', null, '0', '0', '0', '2017-09-13 16:15:00'); +INSERT INTO `store_express` VALUES ('73', '新邦物流', 'xinbangwuliu', null, '0', '0', '0', '2017-09-13 16:15:06'); +INSERT INTO `store_express` VALUES ('74', '信丰物流', 'xinfengwuliu', null, '0', '0', '0', '2017-09-13 16:15:15'); +INSERT INTO `store_express` VALUES ('75', '亚风速递', 'yafengsudi', null, '0', '0', '0', '2017-09-13 16:15:23'); +INSERT INTO `store_express` VALUES ('76', '一邦速递', 'yibangwuliu', null, '0', '0', '0', '2017-09-13 16:15:30'); +INSERT INTO `store_express` VALUES ('77', '优速物流', 'youshuwuliu', null, '0', '0', '0', '2017-09-13 16:15:36'); +INSERT INTO `store_express` VALUES ('78', '邮政包裹挂号信', 'youzhengguonei', null, '0', '3', '0', '2017-09-13 16:15:44'); +INSERT INTO `store_express` VALUES ('79', '邮政国际包裹挂号信', 'youzhengguoji', null, '0', '2', '0', '2017-09-13 16:15:51'); +INSERT INTO `store_express` VALUES ('80', '远成物流', 'yuanchengwuliu', null, '0', '0', '0', '2017-09-13 16:15:57'); +INSERT INTO `store_express` VALUES ('81', '圆通速递', 'yuantong', null, '1', '1', '0', '2017-09-13 16:16:03'); +INSERT INTO `store_express` VALUES ('82', '源伟丰快递', 'yuanweifeng', null, '0', '0', '0', '2017-09-13 16:16:10'); +INSERT INTO `store_express` VALUES ('83', '元智捷诚快递', 'yuanzhijiecheng', null, '0', '0', '0', '2017-09-13 16:16:17'); +INSERT INTO `store_express` VALUES ('84', '韵达快运', 'yunda', null, '0', '0', '0', '2017-09-13 16:16:24'); +INSERT INTO `store_express` VALUES ('85', '运通快递', 'yuntongkuaidi', null, '0', '0', '0', '2017-09-13 16:16:33'); +INSERT INTO `store_express` VALUES ('86', '越丰物流', 'yuefengwuliu', null, '0', '0', '0', '2017-09-13 16:16:40'); +INSERT INTO `store_express` VALUES ('87', '源安达', 'yad', null, '0', '0', '0', '2017-09-13 16:16:47'); +INSERT INTO `store_express` VALUES ('88', '银捷速递', 'yinjiesudi', null, '0', '0', '0', '2017-09-13 16:16:56'); +INSERT INTO `store_express` VALUES ('89', '宅急送', 'zhaijisong', null, '0', '0', '0', '2017-09-13 16:17:03'); +INSERT INTO `store_express` VALUES ('90', '中铁快运', 'zhongtiekuaiyun', null, '0', '0', '0', '2017-09-13 16:17:10'); +INSERT INTO `store_express` VALUES ('91', '中通速递', 'zhongtong', '', '0', '0', '0', '2017-09-13 16:17:16'); +INSERT INTO `store_express` VALUES ('92', '中邮物流', 'zhongyouwuliu', null, '0', '0', '0', '2017-09-13 16:17:27'); +INSERT INTO `store_express` VALUES ('93', '忠信达', 'zhongxinda', null, '0', '0', '0', '2017-09-13 16:17:34'); +INSERT INTO `store_express` VALUES ('94', '芝麻开门', 'zhimakaimen', null, '0', '0', '0', '2017-09-13 16:17:41'); + +-- ---------------------------- +-- Table structure for store_goods +-- ---------------------------- +DROP TABLE IF EXISTS `store_goods`; +CREATE TABLE `store_goods` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `brand_id` bigint(20) unsigned DEFAULT '0' COMMENT '品牌ID', `cate_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品分类id', @@ -44,14 +154,14 @@ CREATE TABLE `goods` ( ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品主表'; -- ---------------------------- --- Records of goods +-- Records of store_goods -- ---------------------------- -- ---------------------------- --- Table structure for goods_brand +-- Table structure for store_goods_brand -- ---------------------------- -DROP TABLE IF EXISTS `goods_brand`; -CREATE TABLE `goods_brand` ( +DROP TABLE IF EXISTS `store_goods_brand`; +CREATE TABLE `store_goods_brand` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `brand_logo` varchar(1024) DEFAULT '' COMMENT '品牌logo', `brand_cover` varchar(1024) DEFAULT '' COMMENT '品牌封面', @@ -63,17 +173,17 @@ CREATE TABLE `goods_brand` ( `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商品产品品牌'; +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='产品品牌'; -- ---------------------------- --- Records of goods_brand +-- Records of store_goods_brand -- ---------------------------- -- ---------------------------- --- Table structure for goods_cate +-- Table structure for store_goods_cate -- ---------------------------- -DROP TABLE IF EXISTS `goods_cate`; -CREATE TABLE `goods_cate` ( +DROP TABLE IF EXISTS `store_goods_cate`; +CREATE TABLE `store_goods_cate` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `pid` bigint(20) unsigned DEFAULT '0' COMMENT '上级分类编号', `brand_id` bigint(20) DEFAULT '0' COMMENT '品牌ID', @@ -87,14 +197,14 @@ CREATE TABLE `goods_cate` ( ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品分类'; -- ---------------------------- --- Records of goods_cate +-- Records of store_goods_cate -- ---------------------------- -- ---------------------------- --- Table structure for goods_list +-- Table structure for store_goods_list -- ---------------------------- -DROP TABLE IF EXISTS `goods_list`; -CREATE TABLE `goods_list` ( +DROP TABLE IF EXISTS `store_goods_list`; +CREATE TABLE `store_goods_list` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `goods_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品ID', `goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格名称', @@ -110,14 +220,14 @@ CREATE TABLE `goods_list` ( ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品列表'; -- ---------------------------- --- Records of goods_list +-- Records of store_goods_list -- ---------------------------- -- ---------------------------- --- Table structure for goods_spec +-- Table structure for store_goods_spec -- ---------------------------- -DROP TABLE IF EXISTS `goods_spec`; -CREATE TABLE `goods_spec` ( +DROP TABLE IF EXISTS `store_goods_spec`; +CREATE TABLE `store_goods_spec` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `mch_id` bigint(20) unsigned DEFAULT '0' COMMENT '商户ID', `spec_title` varchar(255) DEFAULT '' COMMENT '商品规格名称', @@ -132,7 +242,152 @@ CREATE TABLE `goods_spec` ( ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品规格'; -- ---------------------------- --- Records of goods_spec +-- Records of store_goods_spec +-- ---------------------------- + +-- ---------------------------- +-- Table structure for store_member +-- ---------------------------- +DROP TABLE IF EXISTS `store_member`; +CREATE TABLE `store_member` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `openid` varchar(100) DEFAULT '' COMMENT '会员微信OPENID', + `phone` varchar(16) DEFAULT '' COMMENT '会员手机号', + `password` varchar(64) NOT NULL DEFAULT '' COMMENT '登录密码', + `nickname` varchar(20) DEFAULT '' COMMENT '会员昵称', + `headimg` varchar(500) DEFAULT '' COMMENT '会员头像', + `sex` char(2) DEFAULT '' COMMENT '性别', + `level` tinyint(2) unsigned DEFAULT '1' COMMENT '会员级别', + `remark` varchar(500) DEFAULT '' COMMENT '会员个性签名', + `status` tinyint(1) unsigned DEFAULT '1' COMMENT '会员状态(1有效,0无效)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`), + UNIQUE KEY `index_store_member_openid` (`openid`) USING BTREE, + KEY `index_store_member_phone` (`phone`) USING BTREE +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员信息'; + +-- ---------------------------- +-- Records of store_member +-- ---------------------------- + +-- ---------------------------- +-- Table structure for store_member_address +-- ---------------------------- +DROP TABLE IF EXISTS `store_member_address`; +CREATE TABLE `store_member_address` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', + `username` varchar(20) DEFAULT '' COMMENT '收货人姓名', + `phone` varchar(16) DEFAULT '' COMMENT '收货手机号', + `province` varchar(50) DEFAULT '' COMMENT '收货地址省份', + `city` varchar(50) DEFAULT '' COMMENT '收货地址城市', + `area` varchar(255) DEFAULT '' COMMENT '收货地址区域', + `address` varchar(255) DEFAULT '' COMMENT '收货详细地址', + `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0无效, 1新快递)', + `is_default` tinyint(1) unsigned DEFAULT '1' COMMENT '默认收货地址', + `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员收货地址'; + +-- ---------------------------- +-- Records of store_member_address +-- ---------------------------- + +-- ---------------------------- +-- Table structure for store_order +-- ---------------------------- +DROP TABLE IF EXISTS `store_order`; +CREATE TABLE `store_order` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `type` tinyint(1) unsigned DEFAULT '1' COMMENT '订单类型(1普通订单,2积分订单)', + `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', + `order_no` char(10) DEFAULT '' COMMENT '订单号', + `freight_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '快递费', + `goods_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品总金额(不含快递费)', + `real_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '真实支付金额(商品金额+快递金额)', + `is_pay` tinyint(1) unsigned DEFAULT '0' COMMENT '订单支付状态(0.未支付,1.已支付)', + `pay_type` varchar(255) DEFAULT '' COMMENT '支付方式 (wechat微信支付, alipay支付宝支付)', + `pay_no` varchar(100) DEFAULT '' COMMENT '商户交易号', + `pay_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '实际支付金额', + `pay_at` datetime DEFAULT NULL COMMENT '支付时间', + `desc` text COMMENT '订单描述', + `status` bigint(1) unsigned DEFAULT '1' COMMENT '订单状态(0.无效,1.新订单,2.待发货,3.已发货,4.已收货,5.已完成,6.已退货及退款)', + `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`), + KEY `index_store_order_order_no` (`order_no`) USING BTREE, + KEY `index_store_order_status` (`status`) USING BTREE +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单主表'; + +-- ---------------------------- +-- Records of store_order +-- ---------------------------- + +-- ---------------------------- +-- Table structure for store_order_express +-- ---------------------------- +DROP TABLE IF EXISTS `store_order_express`; +CREATE TABLE `store_order_express` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', + `type` tinyint(1) unsigned DEFAULT '0' COMMENT '快递类型(0.订单快递,1.退货快递)', + `order_no` char(10) DEFAULT '' COMMENT '订单编号', + `company_title` varchar(50) DEFAULT '' COMMENT '物流公司名称', + `company_code` varchar(50) DEFAULT '' COMMENT '物流公司编码', + `username` varchar(20) DEFAULT '' COMMENT '收货人姓名', + `phone` varchar(16) DEFAULT '' COMMENT '收货手机号', + `province` varchar(50) DEFAULT NULL COMMENT '收货地址省份', + `city` varchar(50) DEFAULT '' COMMENT '收货地址城市', + `area` varchar(255) DEFAULT '' COMMENT '收货地址区域', + `address` varchar(255) DEFAULT '' COMMENT '收货详细地址', + `send_no` varchar(50) DEFAULT '' COMMENT '实际物流公司单号', + `send_company_title` varchar(50) DEFAULT '' COMMENT '实际发货快递公司', + `send_company_code` varchar(50) DEFAULT '' COMMENT '实际发货快递代码', + `send_username` varchar(255) DEFAULT '' COMMENT '寄件人名称', + `send_phone` varchar(16) DEFAULT '' COMMENT '寄件人手机号', + `send_province` varchar(50) DEFAULT '' COMMENT '寄件人地址省份', + `send_city` varchar(50) DEFAULT '' COMMENT '寄件人地址城市', + `send_area` varchar(255) DEFAULT '' COMMENT '寄件人地址区域', + `send_address` varchar(255) DEFAULT '' COMMENT '寄件人详细地址', + `send_at` datetime DEFAULT NULL COMMENT '快递发货时间', + `desc` text COMMENT '发货描述', + `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.新快递,2.已签收,3.签收失败)', + `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单快递'; + +-- ---------------------------- +-- Records of store_order_express +-- ---------------------------- + +-- ---------------------------- +-- Table structure for store_order_goods +-- ---------------------------- +DROP TABLE IF EXISTS `store_order_goods`; +CREATE TABLE `store_order_goods` ( + `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, + `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', + `order_no` char(10) DEFAULT '' COMMENT '订单编号', + `goods_id` bigint(20) DEFAULT '0' COMMENT '商品ID', + `goods_title` varchar(255) DEFAULT '' COMMENT '商品标签', + `goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格', + `goods_logo` varchar(255) DEFAULT '' COMMENT '商品LOGO', + `goods_image` text COMMENT '商品图片地址', + `market_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '市场价格', + `selling_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品销售价格', + `price_field` varchar(20) DEFAULT 'selling_price' COMMENT '计价字段', + `number` bigint(20) unsigned DEFAULT '0' COMMENT '订单商品数量', + `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', + `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`), + KEY `index_store_order_list_order_no` (`order_no`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单关联商品'; + +-- ---------------------------- +-- Records of store_order_goods -- ---------------------------- -- ---------------------------- @@ -183,7 +438,7 @@ CREATE TABLE `system_config` ( `value` varchar(500) DEFAULT NULL COMMENT '配置值', PRIMARY KEY (`id`), KEY `index_system_config_name` (`name`) -) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='系统参数配置'; +) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统参数配置'; -- ---------------------------- -- Records of system_config @@ -191,8 +446,8 @@ CREATE TABLE `system_config` ( INSERT INTO `system_config` VALUES ('1', 'app_name', 'ThinkAdmin'); INSERT INTO `system_config` VALUES ('2', 'site_name', 'ThinkAdmin'); INSERT INTO `system_config` VALUES ('3', 'app_version', '3.0 dev'); -INSERT INTO `system_config` VALUES ('4', 'site_copy', '©版权所有 2014-2018 楚才科技'); -INSERT INTO `system_config` VALUES ('5', 'browser_icon', 'http://service.thinkadmin.top/static/upload/f47b8fe06e38ae99/08e8398da45583b9.png'); +INSERT INTO `system_config` VALUES ('4', 'site_copy', '©版权所有 2014-2018 楚才科技'); +INSERT INTO `system_config` VALUES ('5', 'browser_icon', 'http://localhost/ThinkAdmin/static/upload/f47b8fe06e38ae99/08e8398da45583b9.png'); INSERT INTO `system_config` VALUES ('6', 'tongji_baidu_key', ''); INSERT INTO `system_config` VALUES ('7', 'miitbeian', '粤ICP备16006642号-2'); INSERT INTO `system_config` VALUES ('8', 'storage_type', 'local'); @@ -209,7 +464,7 @@ INSERT INTO `system_config` VALUES ('18', 'storage_oss_secret', '用你自己的 INSERT INTO `system_config` VALUES ('34', 'wechat_appid', 'wx60a43dd8161666d4'); INSERT INTO `system_config` VALUES ('35', 'wechat_appkey', '9890a0d7c91801a609d151099e95b61a'); INSERT INTO `system_config` VALUES ('36', 'storage_oss_is_https', 'http'); -INSERT INTO `system_config` VALUES ('37', 'wechat_type', 'api'); +INSERT INTO `system_config` VALUES ('37', 'wechat_type', 'thr'); INSERT INTO `system_config` VALUES ('38', 'wechat_token', 'test'); INSERT INTO `system_config` VALUES ('39', 'wechat_appsecret', 'a041bec98ed015d52b99acea5c6a16ef'); INSERT INTO `system_config` VALUES ('40', 'wechat_encodingaeskey', 'BJIUzE0gqlWy0GxfPp4J1oPTBmOrNDIGPNav1YFH5Z5'); @@ -254,7 +509,7 @@ CREATE TABLE `system_menu` ( `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', PRIMARY KEY (`id`), KEY `index_system_menu_node` (`node`) USING BTREE -) ENGINE=InnoDB AUTO_INCREMENT=32 DEFAULT CHARSET=utf8 COMMENT='系统菜单表'; +) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统菜单表'; -- ---------------------------- -- Records of system_menu @@ -268,22 +523,33 @@ INSERT INTO `system_menu` VALUES ('6', '11', '访问节点', '', 'fa fa-fort-awe INSERT INTO `system_menu` VALUES ('7', '0', '后台首页', '', '', 'admin/index/main', '', '_self', '1000', '1', '0', '2018-01-23 13:42:30'); INSERT INTO `system_menu` VALUES ('8', '16', '系统日志', '', 'fa fa-code', 'admin/log/index', '', '_self', '10', '1', '0', '2018-01-24 13:52:58'); INSERT INTO `system_menu` VALUES ('9', '10', '文件存储', '', 'fa fa-stop-circle', 'admin/config/file', '', '_self', '30', '1', '0', '2018-01-25 10:54:28'); -INSERT INTO `system_menu` VALUES ('10', '1', '系统管理', '', 'fa fa-scribd', '#', '', '_self', '200', '1', '0', '2018-01-25 18:14:28'); -INSERT INTO `system_menu` VALUES ('11', '1', '访问权限', '', 'fa fa-anchor', '#', '', '_self', '300', '1', '0', '2018-01-25 18:15:08'); -INSERT INTO `system_menu` VALUES ('16', '1', '日志管理', '', 'fa fa-hashtag', '#', '', '_self', '400', '1', '0', '2018-02-10 16:31:15'); +INSERT INTO `system_menu` VALUES ('10', '1', '系统管理', '', '', '#', '', '_self', '200', '1', '0', '2018-01-25 18:14:28'); +INSERT INTO `system_menu` VALUES ('11', '1', '访问权限', '', '', '#', '', '_self', '300', '1', '0', '2018-01-25 18:15:08'); +INSERT INTO `system_menu` VALUES ('16', '1', '日志管理', '', '', '#', '', '_self', '400', '1', '0', '2018-02-10 16:31:15'); INSERT INTO `system_menu` VALUES ('17', '0', '微信管理', '', '', '#', '', '_self', '8000', '1', '0', '2018-03-06 14:42:49'); -INSERT INTO `system_menu` VALUES ('18', '17', '公众号配置', '', 'fa fa-cogs', '#', '', '_self', '0', '1', '0', '2018-03-06 14:43:05'); +INSERT INTO `system_menu` VALUES ('18', '17', '公众号配置', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:43:05'); INSERT INTO `system_menu` VALUES ('19', '18', '微信授权绑定', '', 'fa fa-cog', 'wechat/config/index', '', '_self', '0', '1', '0', '2018-03-06 14:43:26'); INSERT INTO `system_menu` VALUES ('20', '18', '关注默认回复', '', 'fa fa-comment-o', 'wechat/keys/subscribe', '', '_self', '0', '1', '0', '2018-03-06 14:44:45'); INSERT INTO `system_menu` VALUES ('21', '18', '无反馈默认回复', '', 'fa fa-commenting', 'wechat/keys/defaults', '', '_self', '0', '1', '0', '2018-03-06 14:45:55'); INSERT INTO `system_menu` VALUES ('22', '18', '微信关键字管理', '', 'fa fa-hashtag', 'wechat/keys/index', '', '_self', '0', '1', '0', '2018-03-06 14:46:23'); -INSERT INTO `system_menu` VALUES ('23', '17', '微信服务定制', '', 'fa fa-cubes', '#', '', '_self', '0', '1', '0', '2018-03-06 14:47:11'); +INSERT INTO `system_menu` VALUES ('23', '17', '微信服务定制', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:47:11'); INSERT INTO `system_menu` VALUES ('24', '23', '微信菜单管理', '', 'fa fa-gg-circle', 'wechat/menu/index', '', '_self', '0', '1', '0', '2018-03-06 14:47:39'); INSERT INTO `system_menu` VALUES ('25', '23', '微信图文管理', '', 'fa fa-map-o', 'wechat/news/index', '', '_self', '0', '1', '0', '2018-03-06 14:48:14'); INSERT INTO `system_menu` VALUES ('26', '17', '微信粉丝管理', '', 'fa fa-user', '#', '', '_self', '0', '1', '0', '2018-03-06 14:48:33'); INSERT INTO `system_menu` VALUES ('27', '26', '微信粉丝列表', '', 'fa fa-users', 'wechat/fans/index', '', '_self', '20', '1', '0', '2018-03-06 14:49:04'); -INSERT INTO `system_menu` VALUES ('28', '26', '微信黑名单管理', '', 'fa fa-user-times', 'wechat/block/index', '', '_self', '30', '1', '0', '2018-03-06 14:49:22'); +INSERT INTO `system_menu` VALUES ('28', '26', '微信黑名单管理', '', 'fa fa-user-times', 'wechat/fans_block/index', '', '_self', '30', '1', '0', '2018-03-06 14:49:22'); INSERT INTO `system_menu` VALUES ('29', '26', '微信标签管理', '', 'fa fa-tags', 'wechat/tags/index', '', '_self', '10', '1', '0', '2018-03-06 14:49:39'); +INSERT INTO `system_menu` VALUES ('32', '0', '商城管理', '', '', '#', '', '_self', '2000', '1', '0', '2018-03-20 16:46:07'); +INSERT INTO `system_menu` VALUES ('33', '32', '商品管理', '', '', '#', '', '_self', '0', '1', '0', '2018-03-20 16:46:21'); +INSERT INTO `system_menu` VALUES ('34', '33', '产品管理', '', 'fa fa-modx', 'store/goods/index', '', '_self', '0', '1', '0', '2018-03-20 16:46:45'); +INSERT INTO `system_menu` VALUES ('35', '33', '规格管理', '', 'fa fa-hashtag', 'store/goods_spec/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:08'); +INSERT INTO `system_menu` VALUES ('36', '33', '分类管理', '', 'fa fa-product-hunt', 'store/goods_cate/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:50'); +INSERT INTO `system_menu` VALUES ('37', '33', '品牌管理', '', 'fa fa-scribd', 'store/goods_brand/index', '', '_self', '0', '1', '0', '2018-03-20 16:48:05'); +INSERT INTO `system_menu` VALUES ('38', '32', '订单管理', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:07:36'); +INSERT INTO `system_menu` VALUES ('39', '38', '订单列表', '', 'fa fa-adjust', 'store/order/index', '', '_self', '0', '1', '0', '2018-04-21 15:07:54'); +INSERT INTO `system_menu` VALUES ('40', '32', '商城配置', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:08:17'); +INSERT INTO `system_menu` VALUES ('41', '40', '参数管理', '', '', '#', '', '_self', '0', '0', '0', '2018-04-21 15:08:25'); +INSERT INTO `system_menu` VALUES ('42', '40', '快递公司', '', 'fa fa-mixcloud', 'store/express/index', '', '_self', '0', '1', '0', '2018-04-21 15:08:50'); -- ---------------------------- -- Table structure for system_node @@ -299,87 +565,125 @@ CREATE TABLE `system_node` ( `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', PRIMARY KEY (`id`), KEY `index_system_node_node` (`node`) -) ENGINE=InnoDB AUTO_INCREMENT=230 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='系统节点表'; +) ENGINE=InnoDB AUTO_INCREMENT=145 DEFAULT CHARSET=utf8 COMMENT='系统节点表'; -- ---------------------------- -- Records of system_node -- ---------------------------- -INSERT INTO `system_node` VALUES ('1', 'admin', '系统管理', '0', '1', '1', '2018-01-23 12:39:13'); -INSERT INTO `system_node` VALUES ('2', 'admin/auth', '权限管理', '0', '1', '1', '2018-01-23 12:39:14'); -INSERT INTO `system_node` VALUES ('3', 'admin/auth/index', '权限列表', '1', '1', '1', '2018-01-23 12:39:14'); -INSERT INTO `system_node` VALUES ('4', 'admin/auth/apply', '访问授权', '0', '1', '1', '2018-01-23 12:39:19'); -INSERT INTO `system_node` VALUES ('5', 'admin/auth/add', '添加权限', '0', '1', '1', '2018-01-23 12:39:22'); -INSERT INTO `system_node` VALUES ('6', 'admin/auth/edit', '编辑权限', '0', '1', '1', '2018-01-23 12:39:23'); -INSERT INTO `system_node` VALUES ('7', 'admin/auth/forbid', '禁用权限', '0', '1', '1', '2018-01-23 12:39:23'); -INSERT INTO `system_node` VALUES ('8', 'admin/auth/resume', '启用权限', '0', '1', '1', '2018-01-23 12:39:24'); -INSERT INTO `system_node` VALUES ('9', 'admin/auth/del', '删除权限', '0', '1', '1', '2018-01-23 12:39:25'); -INSERT INTO `system_node` VALUES ('10', 'admin/config/index', '系统参数', '1', '1', '1', '2018-01-23 12:39:25'); -INSERT INTO `system_node` VALUES ('11', 'admin/config/file', '文件存储', '0', '1', '1', '2018-01-23 12:39:26'); -INSERT INTO `system_node` VALUES ('13', 'admin/log/index', '日志记录', '1', '1', '1', '2018-01-23 12:39:28'); -INSERT INTO `system_node` VALUES ('14', 'admin/log/sms', '短信记录', '0', '1', '1', '2018-01-23 12:39:29'); -INSERT INTO `system_node` VALUES ('15', 'admin/log/del', '日志删除', '0', '1', '1', '2018-01-23 12:39:29'); -INSERT INTO `system_node` VALUES ('16', 'admin/menu/index', '系统菜单列表', '1', '1', '1', '2018-01-23 12:39:31'); -INSERT INTO `system_node` VALUES ('17', 'admin/menu/add', '添加系统菜单', '0', '1', '1', '2018-01-23 12:39:31'); -INSERT INTO `system_node` VALUES ('18', 'admin/menu/edit', '编辑系统菜单', '0', '1', '1', '2018-01-23 12:39:32'); -INSERT INTO `system_node` VALUES ('19', 'admin/menu/del', '删除系统菜单', '0', '1', '1', '2018-01-23 12:39:33'); -INSERT INTO `system_node` VALUES ('20', 'admin/menu/forbid', '禁用系统菜单', '0', '1', '1', '2018-01-23 12:39:33'); -INSERT INTO `system_node` VALUES ('21', 'admin/menu/resume', '启用系统菜单', '0', '1', '1', '2018-01-23 12:39:34'); -INSERT INTO `system_node` VALUES ('22', 'admin/node/index', '系统节点列表', '1', '1', '1', '2018-01-23 12:39:36'); -INSERT INTO `system_node` VALUES ('23', 'admin/node/save', '保存节点信息', '0', '1', '1', '2018-01-23 12:39:36'); -INSERT INTO `system_node` VALUES ('24', 'admin/user/index', '系统用户列表', '1', '1', '1', '2018-01-23 12:39:37'); -INSERT INTO `system_node` VALUES ('25', 'admin/user/auth', '用户授权操作', '0', '1', '1', '2018-01-23 12:39:38'); -INSERT INTO `system_node` VALUES ('26', 'admin/user/add', '添加系统用户', '0', '1', '1', '2018-01-23 12:39:39'); -INSERT INTO `system_node` VALUES ('27', 'admin/user/edit', '编辑系统用户', '0', '1', '1', '2018-01-23 12:39:39'); -INSERT INTO `system_node` VALUES ('28', 'admin/user/pass', '修改用户密码', '0', '1', '1', '2018-01-23 12:39:40'); -INSERT INTO `system_node` VALUES ('29', 'admin/user/del', '删除系统用户', '0', '1', '1', '2018-01-23 12:39:41'); -INSERT INTO `system_node` VALUES ('30', 'admin/user/forbid', '禁用系统用户', '0', '1', '1', '2018-01-23 12:39:41'); -INSERT INTO `system_node` VALUES ('31', 'admin/user/resume', '启用系统用户', '0', '1', '1', '2018-01-23 12:39:42'); -INSERT INTO `system_node` VALUES ('32', 'admin/config', '系统配置', '0', '1', '1', '2018-01-23 13:34:37'); -INSERT INTO `system_node` VALUES ('33', 'admin/log', '日志管理', '0', '1', '1', '2018-01-23 13:34:48'); -INSERT INTO `system_node` VALUES ('34', 'admin/menu', '系统菜单管理', '0', '1', '1', '2018-01-23 13:34:58'); -INSERT INTO `system_node` VALUES ('35', 'admin/node', '系统节点管理', '0', '1', '1', '2018-01-23 13:35:17'); -INSERT INTO `system_node` VALUES ('36', 'admin/user', '系统用户管理', '0', '1', '1', '2018-01-23 13:35:26'); -INSERT INTO `system_node` VALUES ('37', 'wechat', '微信管理', '0', '1', '1', '2018-02-06 11:53:21'); -INSERT INTO `system_node` VALUES ('38', 'wechat/config', '公众号对接', '0', '1', '1', '2018-02-06 11:53:32'); -INSERT INTO `system_node` VALUES ('39', 'wechat/config/index', '公众号对接', '1', '1', '1', '2018-02-06 11:53:32'); -INSERT INTO `system_node` VALUES ('45', 'wechat/block', '黑名单', '0', '1', '1', '2018-03-06 14:37:37'); -INSERT INTO `system_node` VALUES ('46', 'wechat/block/index', '黑名单列表', '1', '1', '1', '2018-03-06 14:37:47'); -INSERT INTO `system_node` VALUES ('47', 'wechat/block/backdel', '移出黑名单', '0', '1', '1', '2018-03-06 14:37:49'); -INSERT INTO `system_node` VALUES ('48', 'wechat/fans', '粉丝管理', '0', '1', '1', '2018-03-06 14:38:06'); -INSERT INTO `system_node` VALUES ('49', 'wechat/fans/index', '粉丝列表', '1', '1', '1', '2018-03-06 14:38:25'); -INSERT INTO `system_node` VALUES ('50', 'wechat/fans/backadd', '移入黑名单', '0', '1', '1', '2018-03-06 14:38:35'); -INSERT INTO `system_node` VALUES ('51', 'wechat/fans/tagset', '标签设置', '0', '1', '1', '2018-03-06 14:38:36'); -INSERT INTO `system_node` VALUES ('52', 'wechat/fans/tagadd', '添加标签', '0', '1', '1', '2018-03-06 14:38:37'); -INSERT INTO `system_node` VALUES ('53', 'wechat/fans/tagdel', '删除标签', '0', '1', '1', '2018-03-06 14:38:38'); -INSERT INTO `system_node` VALUES ('54', 'wechat/fans/sync', '同步粉丝', '0', '1', '1', '2018-03-06 14:38:38'); -INSERT INTO `system_node` VALUES ('55', 'wechat/keys', '关键字管理', '0', '1', '1', '2018-03-06 14:39:21'); -INSERT INTO `system_node` VALUES ('56', 'wechat/keys/index', '关键字列表', '1', '1', '1', '2018-03-06 14:39:25'); -INSERT INTO `system_node` VALUES ('57', 'wechat/keys/add', '添加关键字', '0', '1', '1', '2018-03-06 14:39:27'); -INSERT INTO `system_node` VALUES ('58', 'wechat/keys/edit', '编辑关键字', '0', '1', '1', '2018-03-06 14:39:28'); -INSERT INTO `system_node` VALUES ('59', 'wechat/keys/del', '删除关键字', '0', '1', '1', '2018-03-06 14:39:42'); -INSERT INTO `system_node` VALUES ('60', 'wechat/keys/forbid', '禁用关键字', '0', '1', '1', '2018-03-06 14:39:55'); -INSERT INTO `system_node` VALUES ('61', 'wechat/keys/resume', '启用关键字', '0', '1', '1', '2018-03-06 14:40:01'); -INSERT INTO `system_node` VALUES ('62', 'wechat/keys/subscribe', '关注默认回复', '1', '1', '1', '2018-03-06 14:40:12'); -INSERT INTO `system_node` VALUES ('63', 'wechat/keys/defaults', '无反馈默认回复', '1', '1', '1', '2018-03-06 14:40:27'); -INSERT INTO `system_node` VALUES ('64', 'wechat/menu', '微信菜单管理', '0', '1', '1', '2018-03-06 14:40:37'); -INSERT INTO `system_node` VALUES ('65', 'wechat/menu/index', '微信菜单管理', '1', '1', '1', '2018-03-06 14:40:41'); -INSERT INTO `system_node` VALUES ('66', 'wechat/menu/edit', '编辑发布菜单', '0', '1', '1', '2018-03-06 14:40:53'); -INSERT INTO `system_node` VALUES ('67', 'wechat/menu/cancel', '取消发布菜单', '0', '1', '1', '2018-03-06 14:41:01'); -INSERT INTO `system_node` VALUES ('68', 'wechat/news', '图文内容管理', '0', '1', '1', '2018-03-06 14:41:13'); -INSERT INTO `system_node` VALUES ('69', 'wechat/news/index', '图文内容管理', '1', '1', '1', '2018-03-06 14:41:20'); -INSERT INTO `system_node` VALUES ('70', 'wechat/news/select', '图文选择器', '0', '1', '1', '2018-03-06 14:41:22'); -INSERT INTO `system_node` VALUES ('71', 'wechat/news/image', '图文选择器', '0', '1', '1', '2018-03-06 14:41:22'); -INSERT INTO `system_node` VALUES ('72', 'wechat/news/add', '添加图文', '0', '1', '1', '2018-03-06 14:41:23'); -INSERT INTO `system_node` VALUES ('73', 'wechat/news/del', '删除图文', '0', '1', '1', '2018-03-06 14:41:23'); -INSERT INTO `system_node` VALUES ('74', 'wechat/news/push', '推荐图文', '0', '1', '1', '2018-03-06 14:41:24'); -INSERT INTO `system_node` VALUES ('75', 'wechat/news/edit', '编辑图文', '0', '1', '1', '2018-03-06 14:41:25'); -INSERT INTO `system_node` VALUES ('76', 'wechat/tags', '标签管理', '0', '1', '1', '2018-03-06 14:42:06'); -INSERT INTO `system_node` VALUES ('77', 'wechat/tags/index', '标签列表', '1', '1', '1', '2018-03-06 14:42:09'); -INSERT INTO `system_node` VALUES ('78', 'wechat/tags/add', '添加标签', '0', '1', '1', '2018-03-06 14:42:14'); -INSERT INTO `system_node` VALUES ('79', 'wechat/tags/edit', '编辑标签', '0', '1', '1', '2018-03-06 14:42:17'); -INSERT INTO `system_node` VALUES ('80', 'wechat/tags/del', '删除标签', '0', '1', '1', '2018-03-06 14:42:20'); -INSERT INTO `system_node` VALUES ('81', 'wechat/tags/sync', '同步标签', '0', '1', '1', '2018-03-06 14:42:23'); -INSERT INTO `system_node` VALUES ('229', 'admin/node/clear', '清理无效记录', '0', '1', '1', '2018-03-09 12:24:31'); +INSERT INTO `system_node` VALUES ('13', 'admin', '系统设置', '0', '1', '1', '2018-05-04 11:02:34'); +INSERT INTO `system_node` VALUES ('14', 'admin/auth', '权限管理', '0', '1', '1', '2018-05-04 11:06:55'); +INSERT INTO `system_node` VALUES ('15', 'admin/auth/index', '权限列表', '1', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('16', 'admin/auth/apply', '权限配置', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('17', 'admin/auth/add', '添加权限', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('18', 'admin/auth/edit', '编辑权限', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('19', 'admin/auth/forbid', '禁用权限', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('20', 'admin/auth/resume', '启用权限', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('21', 'admin/auth/del', '删除权限', '0', '1', '1', '2018-05-04 11:06:56'); +INSERT INTO `system_node` VALUES ('22', 'admin/config', '系统配置', '0', '1', '1', '2018-05-04 11:08:18'); +INSERT INTO `system_node` VALUES ('23', 'admin/config/index', '系统参数', '1', '1', '1', '2018-05-04 11:08:25'); +INSERT INTO `system_node` VALUES ('24', 'admin/config/file', '文件存储', '1', '1', '1', '2018-05-04 11:08:27'); +INSERT INTO `system_node` VALUES ('25', 'admin/log', '日志管理', '0', '1', '1', '2018-05-04 11:08:43'); +INSERT INTO `system_node` VALUES ('26', 'admin/log/index', '日志管理', '1', '1', '1', '2018-05-04 11:08:43'); +INSERT INTO `system_node` VALUES ('28', 'admin/log/del', '日志删除', '0', '1', '1', '2018-05-04 11:08:43'); +INSERT INTO `system_node` VALUES ('29', 'admin/menu', '系统菜单', '0', '1', '1', '2018-05-04 11:09:54'); +INSERT INTO `system_node` VALUES ('30', 'admin/menu/index', '菜单列表', '1', '1', '1', '2018-05-04 11:09:54'); +INSERT INTO `system_node` VALUES ('31', 'admin/menu/add', '添加菜单', '0', '1', '1', '2018-05-04 11:09:55'); +INSERT INTO `system_node` VALUES ('32', 'admin/menu/edit', '编辑菜单', '0', '1', '1', '2018-05-04 11:09:55'); +INSERT INTO `system_node` VALUES ('33', 'admin/menu/del', '删除菜单', '0', '1', '1', '2018-05-04 11:09:55'); +INSERT INTO `system_node` VALUES ('34', 'admin/menu/forbid', '禁用菜单', '0', '1', '1', '2018-05-04 11:09:55'); +INSERT INTO `system_node` VALUES ('35', 'admin/menu/resume', '启用菜单', '0', '1', '1', '2018-05-04 11:09:55'); +INSERT INTO `system_node` VALUES ('36', 'admin/node', '节点管理', '0', '1', '1', '2018-05-04 11:10:20'); +INSERT INTO `system_node` VALUES ('37', 'admin/node/index', '节点列表', '1', '1', '1', '2018-05-04 11:10:20'); +INSERT INTO `system_node` VALUES ('38', 'admin/node/clear', '清理节点', '0', '1', '1', '2018-05-04 11:10:21'); +INSERT INTO `system_node` VALUES ('39', 'admin/node/save', '更新节点', '0', '1', '1', '2018-05-04 11:10:21'); +INSERT INTO `system_node` VALUES ('40', 'admin/user', '系统用户', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('41', 'admin/user/index', '用户列表', '1', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('42', 'admin/user/auth', '用户授权', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('43', 'admin/user/add', '添加用户', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('44', 'admin/user/edit', '编辑用户', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('45', 'admin/user/pass', '修改密码', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('46', 'admin/user/del', '删除用户', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('47', 'admin/user/forbid', '禁用启用', '0', '1', '1', '2018-05-04 11:10:43'); +INSERT INTO `system_node` VALUES ('48', 'admin/user/resume', '启用用户', '0', '1', '1', '2018-05-04 11:10:44'); +INSERT INTO `system_node` VALUES ('49', 'store', '商城管理', '0', '1', '1', '2018-05-04 11:11:28'); +INSERT INTO `system_node` VALUES ('50', 'store/express', '快递公司管理', '0', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('51', 'store/express/index', '快递公司列表', '1', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('52', 'store/express/add', '添加快递公司', '0', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('53', 'store/express/edit', '编辑快递公司', '0', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('54', 'store/express/del', '删除快递公司', '0', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('55', 'store/express/forbid', '禁用快递公司', '0', '1', '1', '2018-05-04 11:11:39'); +INSERT INTO `system_node` VALUES ('56', 'store/express/resume', '启用快递公司', '0', '1', '1', '2018-05-04 11:11:40'); +INSERT INTO `system_node` VALUES ('57', 'store/order', '订单管理', '0', '1', '1', '2018-05-04 11:12:14'); +INSERT INTO `system_node` VALUES ('58', 'store/order/index', '订单列表', '1', '1', '1', '2018-05-04 11:12:17'); +INSERT INTO `system_node` VALUES ('59', 'store/order/address', '修改地址', '0', '1', '1', '2018-05-04 11:12:19'); +INSERT INTO `system_node` VALUES ('76', 'wechat', '微信管理', '0', '1', '1', '2018-05-04 11:14:59'); +INSERT INTO `system_node` VALUES ('78', 'wechat/config', '微信对接管理', '0', '1', '1', '2018-05-04 11:16:20'); +INSERT INTO `system_node` VALUES ('79', 'wechat/config/index', '微信对接配置', '1', '1', '1', '2018-05-04 11:16:23'); +INSERT INTO `system_node` VALUES ('80', 'wechat/fans', '微信粉丝管理', '0', '1', '1', '2018-05-04 11:16:31'); +INSERT INTO `system_node` VALUES ('81', 'wechat/fans/index', '微信粉丝列表', '1', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('82', 'wechat/fans/backadd', '微信粉丝拉黑', '0', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('83', 'wechat/fans/tagset', '设置粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('84', 'wechat/fans/tagadd', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('85', 'wechat/fans/tagdel', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('86', 'wechat/fans/sync', '同步粉丝列表', '0', '1', '1', '2018-05-04 11:16:32'); +INSERT INTO `system_node` VALUES ('87', 'wechat/fans_block', '粉丝黑名单管理', '0', '1', '1', '2018-05-04 11:17:25'); +INSERT INTO `system_node` VALUES ('88', 'wechat/fans_block/index', '粉丝黑名单列表', '1', '1', '1', '2018-05-04 11:17:50'); +INSERT INTO `system_node` VALUES ('89', 'wechat/fans_block/backdel', '移除粉丝黑名单', '0', '1', '1', '2018-05-04 11:17:51'); +INSERT INTO `system_node` VALUES ('90', 'wechat/keys', '微信关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('91', 'wechat/keys/index', '关键字列表', '1', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('92', 'wechat/keys/add', '添加关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('93', 'wechat/keys/edit', '编辑关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('94', 'wechat/keys/del', '删除关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('95', 'wechat/keys/forbid', '禁用关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('96', 'wechat/keys/resume', '启用关键字', '0', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('97', 'wechat/keys/subscribe', '关注回复', '1', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('98', 'wechat/keys/defaults', '默认回复', '1', '1', '1', '2018-05-04 11:18:09'); +INSERT INTO `system_node` VALUES ('99', 'wechat/menu', '微信菜单管理', '0', '1', '1', '2018-05-04 11:18:57'); +INSERT INTO `system_node` VALUES ('100', 'wechat/menu/index', '微信菜单展示', '1', '1', '1', '2018-05-04 11:19:10'); +INSERT INTO `system_node` VALUES ('101', 'wechat/menu/edit', '编辑微信菜单', '0', '1', '1', '2018-05-04 11:19:22'); +INSERT INTO `system_node` VALUES ('102', 'wechat/menu/cancel', '取消微信菜单', '0', '1', '1', '2018-05-04 11:19:26'); +INSERT INTO `system_node` VALUES ('103', 'wechat/news/index', '微信图文列表', '1', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('104', 'wechat/news/select', '微信图文选择', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('105', 'wechat/news/image', '微信图片选择', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('106', 'wechat/news/add', '添加微信图文', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('107', 'wechat/news/edit', '编辑微信图文', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('108', 'wechat/news/del', '删除微信图文', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('109', 'wechat/news/push', '推送微信图文', '0', '1', '1', '2018-05-04 11:19:28'); +INSERT INTO `system_node` VALUES ('110', 'wechat/news', '微信图文管理', '0', '1', '1', '2018-05-04 11:19:35'); +INSERT INTO `system_node` VALUES ('111', 'wechat/tags', '微信粉丝标签管理', '0', '1', '1', '2018-05-04 11:20:28'); +INSERT INTO `system_node` VALUES ('112', 'wechat/tags/index', '粉丝标签列表', '1', '1', '1', '2018-05-04 11:20:28'); +INSERT INTO `system_node` VALUES ('113', 'wechat/tags/add', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:20:28'); +INSERT INTO `system_node` VALUES ('114', 'wechat/tags/edit', '编辑粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); +INSERT INTO `system_node` VALUES ('115', 'wechat/tags/del', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); +INSERT INTO `system_node` VALUES ('116', 'wechat/tags/sync', '同步粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); +INSERT INTO `system_node` VALUES ('117', 'store/goods', '商品管理', '0', '1', '1', '2018-05-04 11:29:55'); +INSERT INTO `system_node` VALUES ('118', 'store/goods/index', '商品列表', '1', '1', '1', '2018-05-04 11:29:56'); +INSERT INTO `system_node` VALUES ('119', 'store/goods/add', '添加商品', '0', '1', '1', '2018-05-04 11:29:56'); +INSERT INTO `system_node` VALUES ('120', 'store/goods/edit', '编辑商品', '0', '1', '1', '2018-05-04 11:29:56'); +INSERT INTO `system_node` VALUES ('121', 'store/goods/del', '删除商品', '0', '1', '1', '2018-05-04 11:29:56'); +INSERT INTO `system_node` VALUES ('122', 'store/goods/forbid', '下架商品', '0', '1', '1', '2018-05-04 11:29:56'); +INSERT INTO `system_node` VALUES ('123', 'store/goods/resume', '上架商品', '0', '1', '1', '2018-05-04 11:29:57'); +INSERT INTO `system_node` VALUES ('124', 'store/goods_brand', '商品品牌管理', '0', '1', '1', '2018-05-04 11:30:44'); +INSERT INTO `system_node` VALUES ('125', 'store/goods_brand/index', '商品品牌列表', '1', '1', '1', '2018-05-04 11:30:52'); +INSERT INTO `system_node` VALUES ('126', 'store/goods_brand/add', '添加商品品牌', '0', '1', '1', '2018-05-04 11:30:55'); +INSERT INTO `system_node` VALUES ('127', 'store/goods_brand/edit', '编辑商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); +INSERT INTO `system_node` VALUES ('128', 'store/goods_brand/del', '删除商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); +INSERT INTO `system_node` VALUES ('129', 'store/goods_brand/forbid', '禁用商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); +INSERT INTO `system_node` VALUES ('130', 'store/goods_brand/resume', '启用商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); +INSERT INTO `system_node` VALUES ('131', 'store/goods_cate', '商品分类管理', '0', '1', '1', '2018-05-04 11:31:19'); +INSERT INTO `system_node` VALUES ('132', 'store/goods_cate/index', '商品分类列表', '1', '1', '1', '2018-05-04 11:31:23'); +INSERT INTO `system_node` VALUES ('133', 'store/goods_cate/add', '添加商品分类', '0', '1', '1', '2018-05-04 11:31:23'); +INSERT INTO `system_node` VALUES ('134', 'store/goods_cate/edit', '编辑商品分类', '0', '1', '1', '2018-05-04 11:31:23'); +INSERT INTO `system_node` VALUES ('135', 'store/goods_cate/del', '删除商品分类', '0', '1', '1', '2018-05-04 11:31:24'); +INSERT INTO `system_node` VALUES ('136', 'store/goods_cate/forbid', '禁用商品分类', '0', '1', '1', '2018-05-04 11:31:24'); +INSERT INTO `system_node` VALUES ('137', 'store/goods_cate/resume', '启用商品分类', '0', '1', '1', '2018-05-04 11:31:24'); +INSERT INTO `system_node` VALUES ('138', 'store/goods_spec', '商品规格管理', '0', '1', '1', '2018-05-04 11:31:47'); +INSERT INTO `system_node` VALUES ('139', 'store/goods_spec/index', '商品规格列表', '1', '1', '1', '2018-05-04 11:31:47'); +INSERT INTO `system_node` VALUES ('140', 'store/goods_spec/add', '添加商品规格', '0', '1', '1', '2018-05-04 11:31:47'); +INSERT INTO `system_node` VALUES ('141', 'store/goods_spec/edit', '编辑商品规格', '0', '1', '1', '2018-05-04 11:31:48'); +INSERT INTO `system_node` VALUES ('142', 'store/goods_spec/del', '删除商品规格', '0', '1', '1', '2018-05-04 11:31:48'); +INSERT INTO `system_node` VALUES ('143', 'store/goods_spec/forbid', '禁用商品规格', '0', '1', '1', '2018-05-04 11:31:48'); +INSERT INTO `system_node` VALUES ('144', 'store/goods_spec/resume', '启用商品规格', '0', '1', '1', '2018-05-04 11:31:48'); -- ---------------------------- -- Table structure for system_sequence @@ -426,7 +730,7 @@ CREATE TABLE `system_user` ( -- ---------------------------- -- Records of system_user -- ---------------------------- -INSERT INTO `system_user` VALUES ('10000', 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '18993368867', '', '23296', '2018-03-23 17:05:40', '1', '2,4', '0', null, '2015-11-13 15:14:22'); +INSERT INTO `system_user` VALUES ('10000', 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '', '', '22973', '2018-03-26 17:06:48', '1', '2,4', '0', null, '2015-11-13 15:14:22'); -- ---------------------------- -- Table structure for wechat_fans diff --git a/application/admin/controller/Log.php b/application/admin/controller/Log.php index d909b9e76..d9ae070dd 100644 --- a/application/admin/controller/Log.php +++ b/application/admin/controller/Log.php @@ -75,30 +75,6 @@ class Log extends BasicAdmin } } - /** - * 短信发送记录 - * @return array|string - * @throws \think\Exception - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - */ - public function sms() - { - // 日志数据库对象 - $this->title = '短信发送日志'; - $get = $this->request->get(); - $db = Db::name('MemberSmsHistory'); - foreach (['phone', 'content', 'result'] as $key) { - (isset($get[$key]) && $get[$key] !== '') && $db->whereLike($key, "%{$get[$key]}%"); - } - if (isset($get['date']) && $get['date'] !== '') { - list($start, $end) = explode(' - ', $get['date']); - $db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); - } - return parent::_list($db->order('id desc')); - } - /** * 日志删除操作 * @throws \think\Exception diff --git a/application/store/controller/Goods.php b/application/store/controller/Goods.php new file mode 100644 index 000000000..f9aa540e5 --- /dev/null +++ b/application/store/controller/Goods.php @@ -0,0 +1,265 @@ + + * @date 2017/03/27 14:43 + */ +class Goods extends BasicAdmin +{ + + /** + * 定义当前操作表名 + * @var string + */ + public $table = 'StoreGoods'; + + /** + * 普通商品 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function index() + { + $this->title = '商品管理'; + $get = $this->request->get(); + $db = Db::name($this->table)->where(['is_deleted' => '0']); + if (isset($get['tags_id']) && $get['tags_id'] !== '') { + $db->whereLike('tags_id', "%,{$get['tags_id']},%"); + } + if (isset($get['goods_title']) && $get['goods_title'] !== '') { + $db->whereLike('goods_title', "%{$get['goods_title']}%"); + } + foreach (['cate_id', 'brand_id'] as $field) { + (isset($get[$field]) && $get[$field] !== '') && $db->where($field, $get[$field]); + } + if (isset($get['create_at']) && $get['create_at'] !== '') { + list($start, $end) = explode(' - ', $get['create_at']); + $db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); + } + return parent::_list($db->order('status desc,sort asc,id desc')); + } + + /** + * 商城数据处理 + * @param array $data + */ + protected function _data_filter(&$data) + { + $result = GoodsService::buildGoodsList($data); + $this->assign([ + 'brands' => $result['brand'], + 'cates' => ToolsService::arr2table($result['cate']), + ]); + } + + /** + * 添加商品 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\Exception + */ + public function add() + { + if ($this->request->isGet()) { + $this->title = '添加商品'; + $this->_form_assign(); + return $this->_form($this->table, 'form'); + } + try { + $data = $this->_form_build_data(); + Db::transaction(function () use ($data) { + $goodsID = Db::name($this->table)->insertGetId($data['main']); + foreach ($data['list'] as &$vo) { + $vo['goods_id'] = $goodsID; + } + Db::name('StoreGoodsList')->insertAll($data['list']); + }); + } catch (HttpResponseException $exception) { + return $exception->getResponse(); + } catch (\Exception $e) { + $this->error('商品添加失败,请稍候再试!'); + } + list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('store/goods/index')]; + $this->success('添加商品成功!', "{$base}#{$url}?spm={$spm}"); + } + + /** + * 编辑商品 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function edit() + { + if (!$this->request->isPost()) { + $goods_id = $this->request->get('id'); + $goods = Db::name($this->table)->where(['id' => $goods_id, 'is_deleted' => '0'])->find(); + empty($goods) && $this->error('需要编辑的商品不存在!'); + $goods['list'] = Db::name('StoreGoodsList')->where(['goods_id' => $goods_id, 'is_deleted' => '0'])->select(); + $this->_form_assign(); + return $this->fetch('form', ['vo' => $goods, 'title' => '编辑商品']); + } + try { + $data = $this->_form_build_data(); + $goods_id = $this->request->post('id'); + $goods = Db::name($this->table)->where(['id' => $goods_id, 'is_deleted' => '0'])->find(); + empty($goods) && $this->error('商品编辑失败,请稍候再试!'); + foreach ($data['list'] as &$vo) { + $vo['goods_id'] = $goods_id; + } + Db::transaction(function () use ($data, $goods_id, $goods) { + // 更新商品主表 + $where = ['id' => $goods_id, 'is_deleted' => '0']; + Db::name('StoreGoods')->where($where)->update(array_merge($goods, $data['main'])); + // 更新商品详细 + Db::name('StoreGoodsList')->where(['goods_id' => $goods_id])->delete(); + Db::name('StoreGoodsList')->insertAll($data['list']); + }); + } catch (HttpResponseException $exception) { + return $exception->getResponse(); + } catch (\Exception $e) { + $this->error('商品编辑失败,请稍候再试!' . $e->getMessage()); + } + list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('store/goods/index')]; + $this->success('商品编辑成功!', "{$base}#{$url}?spm={$spm}"); + } + + /** + * 表单数据处理 + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + protected function _form_assign() + { + list($where, $order) = [['status' => '1', 'is_deleted' => '0'], 'sort asc,id desc']; + $specs = (array)Db::name('StoreGoodsSpec')->where($where)->order($order)->select(); + $brands = (array)Db::name('StoreGoodsBrand')->where($where)->order($order)->select(); + $cates = (array)Db::name('StoreGoodsCate')->where($where)->order($order)->select(); + // 所有的商品信息 + $where = ['is_deleted' => '0', 'status' => '1']; + $goodsListField = 'goods_id,goods_spec,goods_stock,goods_sale'; + $goods = Db::name('StoreGoods')->field('id,goods_title')->where($where)->select(); + $list = Db::name('StoreGoodsList')->field($goodsListField)->where($where)->select(); + foreach ($goods as $k => $g) { + $goods[$k]['list'] = []; + foreach ($list as $v) { + ($g['id'] === $v['goods_id']) && $goods[$k]['list'][] = $v; + } + } + array_unshift($specs, ['spec_title' => ' - 不使用规格模板 -', 'spec_param' => '[]', 'id' => '0']); + $this->assign([ + 'specs' => $specs, + 'cates' => ToolsService::arr2table($cates), + 'brands' => $brands, + 'all' => $goods, + ]); + } + + /** + * 读取POST表单数据 + * @return array + */ + protected function _form_build_data() + { + list($main, $list, $post, $verify) = [[], [], $this->request->post(), false]; + empty($post['goods_logo']) && $this->error('商品LOGO不能为空,请上传后再提交数据!'); + // 商品主数据组装 + $main['cate_id'] = $this->request->post('cate_id', '0'); + $main['spec_id'] = $this->request->post('spec_id', '0'); + $main['brand_id'] = $this->request->post('brand_id', '0'); + $main['goods_logo'] = $this->request->post('goods_logo', ''); + $main['goods_title'] = $this->request->post('goods_title', ''); + $main['goods_video'] = $this->request->post('goods_video', ''); + $main['goods_image'] = $this->request->post('goods_image', ''); + $main['goods_desc'] = $this->request->post('goods_desc', '', null); + $main['goods_content'] = $this->request->post('goods_content', ''); + $main['tags_id'] = ',' . join(',', isset($post['tags_id']) ? $post['tags_id'] : []) . ','; + // 商品从数据组装 + if (!empty($post['goods_spec'])) { + foreach ($post['goods_spec'] as $key => $value) { + $goods = []; + $goods['goods_spec'] = $value; + $goods['market_price'] = $post['market_price'][$key]; + $goods['selling_price'] = $post['selling_price'][$key]; + $goods['status'] = intval(!empty($post['spec_status'][$key])); + !empty($goods['status']) && $verify = true; + $list[] = $goods; + } + } else { + $this->error('没有商品规格或套餐信息哦!'); + } + !$verify && $this->error('没有设置有效的商品规格!'); + return ['main' => $main, 'list' => $list]; + } + + /** + * 删除商品 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function del() + { + if (DataService::update($this->table)) { + $this->success("商品删除成功!", ''); + } + $this->error("商品删除失败,请稍候再试!"); + } + + /** + * 商品禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function forbid() + { + if (DataService::update($this->table)) { + $this->success("商品下架成功!", ''); + } + $this->error("商品下架失败,请稍候再试!"); + } + + /** + * 商品禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function resume() + { + if (DataService::update($this->table)) { + $this->success("商品上架成功!", ''); + } + $this->error("商品上架失败,请稍候再试!"); + } + +} diff --git a/application/store/controller/GoodsBrand.php b/application/store/controller/GoodsBrand.php new file mode 100644 index 000000000..7c6618d70 --- /dev/null +++ b/application/store/controller/GoodsBrand.php @@ -0,0 +1,151 @@ + + * @date 2017/03/27 14:43 + */ +class GoodsBrand extends BasicAdmin +{ + + /** + * 定义当前操作表名 + * @var string + */ + public $table = 'StoreGoodsBrand'; + + /** + * 品牌列表 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function index() + { + $this->title = '品牌管理'; + $get = $this->request->get(); + $db = Db::name($this->table)->where(['is_deleted' => '0']); + if (isset($get['brand_title']) && $get['brand_title'] !== '') { + $db->whereLike('brand_title', "%{$get['brand_title']}%"); + } + if (isset($get['create_at']) && $get['create_at'] !== '') { + list($start, $end) = explode(' - ', $get['create_at']); + $db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); + } + return parent::_list($db->order('sort asc,id desc')); + } + + /** + * 添加品牌 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\Exception + */ + public function add() + { + $this->title = '添加品牌'; + return $this->_form($this->table, 'form'); + } + + /** + * 编辑品牌 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\Exception + */ + public function edit() + { + $this->title = '编辑品牌'; + return $this->_form($this->table, 'form'); + } + + /** + * 表单提交数据处理 + * @param array $data + */ + protected function _form_filter($data) + { + if ($this->request->isPost()) { + empty($data['brand_logo']) && $this->error('请上传品牌Logo图片'); + empty($data['brand_cover']) && $this->error('请上传品牌封面图片'); + } + } + + /** + * 添加成功回跳处理 + * @param bool $result + */ + protected function _form_result($result) + { + if ($result !== false) { + list($base, $spm, $url) = [url('@admin'), $this->request->get('spm'), url('goods/brand/index')]; + $this->success('数据保存成功!', "{$base}#{$url}?spm={$spm}"); + } + } + + /** + * 删除品牌 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function del() + { + if (DataService::update($this->table)) { + $this->success("品牌删除成功!", ''); + } + $this->error("品牌删除失败,请稍候再试!"); + } + + /** + * 品牌禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function forbid() + { + if (DataService::update($this->table)) { + $this->success("品牌禁用成功!", ''); + } + $this->error("品牌禁用失败,请稍候再试!"); + } + + /** + * 品牌签禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function resume() + { + if (DataService::update($this->table)) { + $this->success("品牌启用成功!", ''); + } + $this->error("品牌启用失败,请稍候再试!"); + } + +} diff --git a/application/store/controller/GoodsCate.php b/application/store/controller/GoodsCate.php new file mode 100644 index 000000000..e168d4f87 --- /dev/null +++ b/application/store/controller/GoodsCate.php @@ -0,0 +1,157 @@ + + * @date 2017/03/27 14:43 + */ +class GoodsCate extends BasicAdmin +{ + + /** + * 定义当前操作表名 + * @var string + */ + public $table = 'StoreGoodsCate'; + + /** + * 商品分类列表 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function index() + { + $this->title = '商品分类'; + $db = Db::name($this->table)->where(['is_deleted' => '0']); + return parent::_list($db->order('sort asc,id asc'), false); + } + + /** + * 列表数据处理 + * @param array $data + */ + protected function _index_data_filter(&$data) + { + foreach ($data as &$vo) { + $vo['ids'] = join(',', ToolsService::getArrSubIds($data, $vo['id'])); + } + $data = ToolsService::arr2table($data); + } + + /** + * 添加菜单 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function add() + { + return $this->_form($this->table, 'form'); + } + + /** + * 编辑菜单 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function edit() + { + return $this->_form($this->table, 'form'); + } + + /** + * 表单数据前缀方法 + * @param array $vo + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + protected function _form_filter(&$vo) + { + if ($this->request->isGet()) { + // 读取上级分类 + $where = ['status' => '1', 'is_deleted' => '0']; + $_cates = (array)Db::name($this->table)->where($where)->order('sort desc,id desc')->select(); + array_unshift($_cates, ['id' => 0, 'pid' => -1, 'cate_title' => '--- 顶级分类 ---']); + $cates = ToolsService::arr2table($_cates); + foreach ($cates as $key => &$cate) { + if (isset($vo['pid'])) { + $path = "-{$vo['pid']}-{$vo['id']}"; + if ($vo['pid'] !== '' && (stripos("{$cate['path']}-", "{$path}-") !== false || $cate['path'] === $path)) { + unset($cates[$key]); + } + } + } + $this->assign('cates', $cates); + } + } + + /** + * 删除商品分类 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function del() + { + if (DataService::update($this->table)) { + $this->success("商品分类删除成功!", ''); + } + $this->error("商品分类删除失败,请稍候再试!"); + } + + /** + * 商品分类禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function forbid() + { + if (DataService::update($this->table)) { + $this->success("商品分类禁用成功!", ''); + } + $this->error("商品分类禁用失败,请稍候再试!"); + } + + /** + * 商品分类禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function resume() + { + if (DataService::update($this->table)) { + $this->success("商品分类启用成功!", ''); + } + $this->error("商品分类启用失败,请稍候再试!"); + } + +} diff --git a/application/store/controller/GoodsSpec.php b/application/store/controller/GoodsSpec.php new file mode 100644 index 000000000..73d999e9f --- /dev/null +++ b/application/store/controller/GoodsSpec.php @@ -0,0 +1,157 @@ + + * @date 2017/03/27 14:43 + */ +class GoodsSpec extends BasicAdmin +{ + + /** + * 定义当前操作表名 + * @var string + */ + public $table = 'StoreGoodsSpec'; + + /** + * 商品列表 + * @return array|string + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function index() + { + $this->title = '规格管理(请勿随意修改或删除)'; + $get = $this->request->get(); + $db = Db::name($this->table)->where(['is_deleted' => '0']); + if (isset($get['spec_title']) && $get['spec_title'] !== '') { + $db->whereLike('spec_title', "%{$get['spec_title']}%"); + } + if (isset($get['date']) && $get['date'] !== '') { + list($start, $end) = explode(' - ', $get['date']); + $db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); + } + return parent::_list($db->order('sort asc,id desc')); + } + + /** + * 列表数据处理 + * @param array $data + */ + protected function _index_data_filter(&$data) + { + foreach ($data as &$vo) { + $vo['spec_param'] = json_decode($vo['spec_param'], true); + $vo['spec_param'] = is_array($vo['spec_param']) ? $vo['spec_param'] : []; + } + } + + /** + * 添加商品 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\Exception + */ + public function add() + { + $this->title = '添加规格'; + return $this->_form($this->table, 'form'); + } + + /** + * 编辑商品 + * @return array|string + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\Exception + */ + public function edit() + { + $this->title = '编辑规格'; + return $this->_form($this->table, 'form'); + } + + /** + * 表单数据处理 + * @param array $vo + */ + protected function _form_filter(&$vo) + { + if ($this->request->isPost()) { + $param = json_decode($this->request->post('spec_param', '[]', null), true); + foreach ($param as &$v) { + $count = 1; + while ($count) { + $v['value'] = trim(str_replace([' ', '_', ',', ',', ';', ';'], ' ', $v['value'], $count)); + } + } + $vo['spec_param'] = json_encode($param, JSON_UNESCAPED_UNICODE); + } + } + + /** + * 删除商品规格 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function del() + { + if (DataService::update($this->table)) { + $this->success("商品规格删除成功!", ''); + } + $this->error("商品规格删除失败,请稍候再试!"); + } + + /** + * 商品规格禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function forbid() + { + if (DataService::update($this->table)) { + $this->success("商品规格禁用成功!", ''); + } + $this->error("商品规格禁用失败,请稍候再试!"); + } + + /** + * 商品规格禁用 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function resume() + { + if (DataService::update($this->table)) { + $this->success("商品规格启用成功!", ''); + } + $this->error("商品规格启用失败,请稍候再试!"); + } + +} diff --git a/application/store/controller/wechat/Index.php b/application/store/controller/wechat/Index.php new file mode 100644 index 000000000..77efed4f9 --- /dev/null +++ b/application/store/controller/wechat/Index.php @@ -0,0 +1,24 @@ + '1', 'is_deleted' => '0']; + $cateList = Db::name('StoreGoodsCate')->where($cateWhere)->order('sort asc,id desc')->column($cateField); + // 商品品牌处理 + $brandWhere = ['status' => '1', 'is_deleted' => '0']; + $brandField = 'id,brand_logo,brand_cover,brand_title,brand_desc,brand_detail'; + $brandList = Db::name('StoreGoodsBrand')->where($brandWhere)->order('sort asc,id desc')->column($brandField); + // 无商品列表时 + if (empty($goodsList)) { + return ['list' => $goodsList, 'cate' => $cateList, 'brand' => $brandList]; + } + // 读取商品详情列表 + $specWhere = [['status', 'eq', '1'], ['is_deleted', 'eq', '0'], ['goods_id', 'in', array_column($goodsList, 'id')]]; + $specField = 'id,goods_id,goods_spec,goods_number,market_price,selling_price,goods_stock,goods_sale'; + $specList = Db::name('StoreGoodsList')->where($specWhere)->column($specField); + foreach ($specList as $key => $spec) { + foreach ($goodsList as $goods) { + if ($goods['id'] === $spec['goods_id']) { + $specList[$key]['goods_title'] = $goods['goods_title']; + } + } + if ($spec['goods_spec'] === 'default:default') { + $specList[$key]['goods_spec_alias'] = '默认规格'; + } else { + $specList[$key]['goods_spec_alias'] = str_replace([':', ','], [': ', ', '], $spec['goods_spec']); + } + } + // 商品数据组装 + foreach ($goodsList as $key => $vo) { + // 商品内容处理 + $goodsList[$key]['goods_content'] = $vo['goods_content']; + // 商品品牌处理 + $goodsList[$key]['brand'] = isset($brandList[$vo['brand_id']]) ? $brandList[$vo['brand_id']] : []; + // 商品分类关联 + $goodsList[$key]['cate'] = []; + if (isset($cateList[$vo['cate_id']])) { + $goodsList[$key]['cate'][] = ($tcate = $cateList[$vo['cate_id']]); + while (isset($tcate['pid']) && $tcate['pid'] > 0 && isset($cateList[$tcate['pid']])) { + $goodsList[$key]['cate'][] = ($tcate = $cateList[$tcate['pid']]); + } + $goodsList[$key]['cate'] = array_reverse($goodsList[$key]['cate']); + } + // 商品详细列表关联 + $goodsList[$key]['spec'] = []; + foreach ($specList as $spec) { + if ($vo['id'] === $spec['goods_id']) { + $goodsList[$key]['spec'][] = $spec; + } + } + } + return ['list' => $goodsList, 'cate' => $cateList, 'brand' => $brandList]; + } + + /** + * 同步更新商品库存及售出(@todo 需要重新做库存统计) + * @param int $goods_id 商品ID + * @return array + * @throws \think\Exception + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + * @throws \think\exception\PDOException + */ + public static function syncGoodsStock($goods_id) + { + // 检查商品是否需要更新库存 + $map = ['id' => $goods_id, 'is_deleted' => '0']; + if (!($goods = Db::name('Goods')->where($map)->find())) { + return ['code' => 0, 'msg' => '指定商品信息无法同步库存!']; + } + // 统计入库信息 + $stockField = 'goods_id,goods_spec,ifnull(sum(goods_stock), 0) goods_stock'; + $stockWhere = ['status' => '1', 'is_deleted' => '0', 'goods_id' => $goods_id, 'mch_id' => $mch_id]; + $stockList = (array)Db::name('StoreGoodsStock')->field($stockField)->where($stockWhere)->group('goods_id,goods_spec')->select(); + // 统计销售信息 + $saleField = 'goods_id,goods_spec,ifnull(sum(number), 0) goods_sale'; + $saleWhere = ['status' => '1', 'is_deleted' => '0', 'goods_id' => $goods_id, 'mch_id' => $mch_id]; + $saleList = (array)Db::name('StoreOrderList')->field($saleField)->where($saleWhere)->group('goods_id,goods_spec')->select(); + // 库存置零 + list($where, $total_stock, $total_sale) = [['goods_id' => $goods_id], 0, 0]; + Db::name('StoreGoodsList')->where($where)->update(['goods_stock' => 0, 'goods_sale' => 0, 'mch_id' => $mch_id]); + // 更新商品库存 + foreach ($stockList as $stock) { + $total_stock += intval($stock['goods_stock']); + $where = ['goods_id' => $goods_id, 'goods_spec' => $stock['goods_spec'], 'mch_id' => $mch_id]; + Db::name('StoreGoodsList')->where($where)->update(['goods_stock' => $stock['goods_stock']]); + } + // 更新商品销量 + foreach ($saleList as $sale) { + $total_sale += intval($sale['goods_sale']); + $where = ['goods_id' => $goods_id, 'goods_spec' => $sale['goods_spec'], 'mch_id' => $mch_id]; + Db::name('StoreGoodsList')->where($where)->update(['goods_sale' => $sale['goods_sale']]); + } + // 更新总库存及总销量 + $update = ['package_stock' => $total_stock, 'package_sale' => $total_sale, 'mch_id' => $mch_id]; + Db::name('Goods')->where(['id' => $goods_id])->update($update); + return ['code' => 1, 'msg' => '同步商品库存成功!']; + } + +} \ No newline at end of file diff --git a/application/store/view/goods/form.html b/application/store/view/goods/form.html new file mode 100644 index 000000000..bd8434e01 --- /dev/null +++ b/application/store/view/goods/form.html @@ -0,0 +1,357 @@ +{extend name='admin@public/content'} + +{block name="content"} +
+ + +{/block} + +{block name="style"} + +{/block} \ No newline at end of file diff --git a/application/store/view/goods/index.html b/application/store/view/goods/index.html new file mode 100644 index 000000000..b47420777 --- /dev/null +++ b/application/store/view/goods/index.html @@ -0,0 +1,189 @@ +{extend name='admin@public/content'} + +{block name="button"} + + + + + + + + + + + + + + + + + +{/block} + +{block name="content"} + + + + + + + +{/block} \ No newline at end of file diff --git a/application/store/view/goods_brand/form.html b/application/store/view/goods_brand/form.html new file mode 100644 index 000000000..9db6c4522 --- /dev/null +++ b/application/store/view/goods_brand/form.html @@ -0,0 +1,82 @@ +{extend name='admin@public/content'} + +{block name="content"} + +{/block} \ No newline at end of file diff --git a/application/store/view/goods_brand/index.html b/application/store/view/goods_brand/index.html new file mode 100644 index 000000000..d5ff29458 --- /dev/null +++ b/application/store/view/goods_brand/index.html @@ -0,0 +1,108 @@ +{extend name='admin@public/content'} + +{block name="button"} + + + + + + + + + +{/block} + +{block name="content"} + + + + + + + + +{/block} \ No newline at end of file diff --git a/application/store/view/goods_cate/form.html b/application/store/view/goods_cate/form.html new file mode 100644 index 000000000..9b0906081 --- /dev/null +++ b/application/store/view/goods_cate/form.html @@ -0,0 +1,39 @@ + diff --git a/application/store/view/goods_cate/index.html b/application/store/view/goods_cate/index.html new file mode 100644 index 000000000..5dbdf323b --- /dev/null +++ b/application/store/view/goods_cate/index.html @@ -0,0 +1,83 @@ +{extend name='admin@public/content'} + +{block name="button"} + + + + + + +{/block} + +{block name="content"} + +{/block} \ No newline at end of file diff --git a/application/store/view/goods_spec/form.html b/application/store/view/goods_spec/form.html new file mode 100644 index 000000000..9d60ff2e2 --- /dev/null +++ b/application/store/view/goods_spec/form.html @@ -0,0 +1,200 @@ + diff --git a/application/store/view/goods_spec/index.html b/application/store/view/goods_spec/index.html new file mode 100644 index 000000000..ebe56255c --- /dev/null +++ b/application/store/view/goods_spec/index.html @@ -0,0 +1,116 @@ +{extend name='admin@public/content'} + +{block name="button"} + + + + + + + + + +{/block} + +{block name="content"} + + + + + + + + +{/block} \ No newline at end of file diff --git a/application/tags.php b/application/tags.php index c0dffdc11..30c1a48cb 100644 --- a/application/tags.php +++ b/application/tags.php @@ -14,6 +14,7 @@ namespace think; +use service\NodeService; use think\exception\HttpResponseException; return [ @@ -21,7 +22,7 @@ return [ 'action_begin' => function () { $request = app('request'); list($module, $controller, $action) = [$request->module(), $request->controller(), $request->action()]; - $node = strtolower("{$module}/{$controller}/{$action}"); + $node = NodeService::parseNodeStr("{$module}/{$controller}/{$action}"); $info = Db::name('SystemNode')->cache(true, 30)->where(['node' => $node])->find(); $access = ['is_menu' => intval(!empty($info['is_menu'])), 'is_auth' => intval(!empty($info['is_auth'])), 'is_login' => empty($info['is_auth']) ? intval(!empty($info['is_login'])) : 1]; // 登录状态检查 @@ -34,6 +35,6 @@ return [ throw new HttpResponseException(json(['code' => 0, 'msg' => '抱歉,您没有访问该模块的权限!'])); } // 模板常量声明 - app('view')->init(config('template.'))->assign(['classuri' => "{$module}/{$controller}"]); + app('view')->init(config('template.'))->assign(['classuri' => NodeService::parseNodeStr("{$module}/{$controller}")]); }, ]; diff --git a/application/wechat/controller/Block.php b/application/wechat/controller/FansBlock.php similarity index 99% rename from application/wechat/controller/Block.php rename to application/wechat/controller/FansBlock.php index fc8be81ef..b6c669603 100644 --- a/application/wechat/controller/Block.php +++ b/application/wechat/controller/FansBlock.php @@ -26,7 +26,7 @@ use think\Db; * @author Anyon