cif使用ajax返回的数据,warehouse2.sql

-- phpMyAdmin SQL Dump

-- version phpStudy 2014

-- http://www.phpmyadmin.net

--

-- 主机: localhost

-- 生成日期: 2019 ?09 ?19 ?09:14

-- 服务器版本: 5.5.53

-- PHP 版本: 7.0.12

SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";

SET time_zone = "+00:00";

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;

/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;

/*!40101 SET NAMES utf8 */;

--

-- 数据库: `warehouse1`

--

-- --------------------------------------------------------

--

-- 表的结构 `ob_action_log`

--

CREATE TABLE IF NOT EXISTS `ob_action_log` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',

`member_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '执行会员id',

`username` char(30) NOT NULL DEFAULT '' COMMENT '用户名',

`ip` char(30) NOT NULL DEFAULT '' COMMENT '执行行为者ip',

`name` varchar(50) NOT NULL DEFAULT '' COMMENT '行为名称',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '描述',

`url` varchar(255) NOT NULL DEFAULT '' COMMENT '执行的URL',

`status` tinyint(2) NOT NULL DEFAULT '1' COMMENT '状态',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '执行行为的时间',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 ROW_FORMAT=FIXED COMMENT='行为日志表' AUTO_INCREMENT=1336 ;

--

-- 转存表中的数据 `ob_action_log`

--

INSERT INTO `ob_action_log` (`id`, `member_id`, `username`, `ip`, `name`, `describe`, `url`, `status`, `update_time`, `create_time`) VALUES

(1311, 1, 'admin', '127.0.0.1', '登录', '登录操作,username:admin', '/admin.php/login/loginhandle.html', 1, 0, 1568860177),

(1312, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:仓库管理', '/admin.php/menu/menuadd.html', 1, 0, 1568861472),

(1313, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:人员管理', '/admin.php/menu/menuadd.html', 1, 0, 1568861659),

(1314, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:出库管理', '/admin.php/menu/menuadd.html', 1, 0, 1568861710),

(1315, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:入库管理', '/admin.php/menu/menuadd.html', 1, 0, 1568861735),

(1316, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:商品种类', '/admin.php/menu/menuadd.html', 1, 0, 1568861870),

(1317, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:库存信息', '/admin.php/menu/menuadd.html', 1, 0, 1568861908),

(1318, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:库存数量', '/admin.php/menu/menuadd.html', 1, 0, 1568861946),

(1319, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:盘点库存', '/admin.php/menu/menuadd.html', 1, 0, 1568862026),

(1320, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:入库清单', '/admin.php/menu/menuadd.html', 1, 0, 1568862058),

(1321, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:出库清单', '/admin.php/menu/menuadd.html', 1, 0, 1568862084),

(1322, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:打印清单', '/admin.php/menu/menuadd.html', 1, 0, 1568862120),

(1323, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:增加商品', '/admin.php/menu/menuadd.html', 1, 0, 1568862175),

(1324, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:删除产品', '/admin.php/menu/menuadd.html', 1, 0, 1568862210),

(1325, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:222,value:1', '/admin.php/menu/setsort.html', 1, 0, 1568862217),

(1326, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:223,value:2', '/admin.php/menu/setsort.html', 1, 0, 1568862220),

(1327, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:214,value:2', '/admin.php/menu/setsort.html', 1, 0, 1568862232),

(1328, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:213,value:1', '/admin.php/menu/setsort.html', 1, 0, 1568862237),

(1329, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:215,value:3', '/admin.php/menu/setsort.html', 1, 0, 1568862241),

(1330, 1, 'admin', '127.0.0.1', '数据排序', '数据排序调整,model:Menu,id:216,value:4', '/admin.php/menu/setsort.html', 1, 0, 1568862244),

(1331, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:添加账号', '/admin.php/menu/menuadd.html', 1, 0, 1568862341),

(1332, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:删除账号', '/admin.php/menu/menuadd.html', 1, 0, 1568862397),

(1333, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:个人信息', '/admin.php/menu/menuadd.html', 1, 0, 1568862447),

(1334, 1, 'admin', '127.0.0.1', '登录', '登录操作,username:admin', '/admin.php/login/loginhandle.html', 1, 0, 1568877790),

(1335, 1, 'admin', '127.0.0.1', '新增', '新增菜单,name:人员列表', '/admin.php/menu/menuadd.html', 1, 0, 1568877894);

-- --------------------------------------------------------

--

-- 表的结构 `ob_addon`

--

CREATE TABLE IF NOT EXISTS `ob_addon` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',

`name` varchar(40) NOT NULL DEFAULT '' COMMENT '插件名或标识',

`title` varchar(20) NOT NULL DEFAULT '' COMMENT '中文名称',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '插件描述',

`config` text NOT NULL COMMENT '配置',

`author` varchar(40) NOT NULL DEFAULT '' COMMENT '作者',

`version` varchar(20) NOT NULL DEFAULT '' COMMENT '版本号',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '安装时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='插件表' AUTO_INCREMENT=7 ;

--

-- 转存表中的数据 `ob_addon`

--

INSERT INTO `ob_addon` (`id`, `name`, `title`, `describe`, `config`, `author`, `version`, `status`, `create_time`, `update_time`) VALUES

(3, 'File', '文件上传', '文件上传插件', '', 'Jack', '1.0', 1, 0, 0),

(4, 'Icon', '图标选择', '图标选择插件', '', 'Bigotry', '1.0', 1, 0, 0),

(5, 'Editor', '文本编辑器', '富文本编辑器', '', 'Bigotry', '1.0', 1, 0, 0);

-- --------------------------------------------------------

--

-- 表的结构 `ob_api`

--

CREATE TABLE IF NOT EXISTS `ob_api` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` char(150) NOT NULL DEFAULT '' COMMENT '接口名称',

`group_id` int(6) unsigned NOT NULL DEFAULT '0' COMMENT '接口分组',

`request_type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '请求类型 0:POST 1:GET',

`api_url` char(50) NOT NULL DEFAULT '' COMMENT '请求路径',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '接口描述',

`describe_text` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT '接口富文本描述',

`is_request_data` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否需要请求数据',

`request_data` text NOT NULL COMMENT '请求数据',

`response_data` text NOT NULL COMMENT '响应数据',

`is_response_data` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否需要响应数据',

`is_user_token` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否需要用户token',

`is_response_sign` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否返回数据签名',

`is_request_sign` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否验证请求数据签名',

`response_examples` text NOT NULL COMMENT '响应栗子',

`developer` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '研发者',

`api_status` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '接口状态(0:待研发,1:研发中,2:测试中,3:已完成)',

`is_page` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否为分页接口 0:否 1:是',

`sort` tinyint(5) unsigned NOT NULL DEFAULT '0' COMMENT '排序',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='API表' AUTO_INCREMENT=192 ;

--

-- 转存表中的数据 `ob_api`

--

INSERT INTO `ob_api` (`id`, `name`, `group_id`, `request_type`, `api_url`, `describe`, `describe_text`, `is_request_data`, `request_data`, `response_data`, `is_response_data`, `is_user_token`, `is_response_sign`, `is_request_sign`, `response_examples`, `developer`, `api_status`, `is_page`, `sort`, `status`, `create_time`, `update_time`) VALUES

(186, '登录或注册', 34, 0, 'common/login', '系统登录注册接口,若用户名存在则验证密码正确性,若用户名不存在则注册新用户,返回 user_token 用于操作需验证身份的接口', '', 1, '[{"field_name":"username","data_type":"0","is_require":"1","field_describe":"\\u7528\\u6237\\u540d"},{"field_name":"password","data_type":"0","is_require":"1","field_describe":"\\u5bc6\\u7801"}]', '[{"field_name":"data","data_type":"2","field_describe":"\\u4f1a\\u5458\\u6570\\u636e\\u53causer_token"}]', 1, 0, 1, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "data": {\r\n "member_id": 51,\r\n "nickname": "sadasdas",\r\n "username": "sadasdas",\r\n "create_time": "2017-09-09 13:40:17",\r\n "user_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJPbmVCYXNlIEpXVCIsImlhdCI6MTUwNDkzNTYxNywiZXhwIjoxNTA0OTM2NjE3LCJhdWQiOiJPbmVCYXNlIiwic3ViIjoiT25lQmFzZSIsImRhdGEiOnsibWVtYmVyX2lkIjo1MSwibmlja25hbWUiOiJzYWRhc2RhcyIsInVzZXJuYW1lIjoic2FkYXNkYXMiLCJjcmVhdGVfdGltZSI6IjIwMTctMDktMDkgMTM6NDA6MTcifX0.6PEShODuifNsa-x1TumLoEaR2TCXpUEYgjpD3Mz3GRM"\r\n }\r\n}', 0, 1, 0, 0, 1, 1504501410, 1520504982),

(187, '文章分类列表', 44, 0, 'article/categorylist', '文章分类列表接口', '', 0, '', '[{"field_name":"id","data_type":"0","field_describe":"\\u6587\\u7ae0\\u5206\\u7c7bID"},{"field_name":"name","data_type":"0","field_describe":"\\u6587\\u7ae0\\u5206\\u7c7b\\u540d\\u79f0"}]', 1, 0, 0, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "data": [\r\n {\r\n "id": 2,\r\n "name": "测试文章分类2"\r\n },\r\n {\r\n "id": 1,\r\n "name": "测试文章分类1"\r\n }\r\n ]\r\n}', 0, 0, 0, 2, 1, 1504765581, 1520504982),

(188, '文章列表', 44, 0, 'article/articlelist', '文章列表接口', '', 1, '[{"field_name":"category_id","data_type":"0","is_require":"0","field_describe":"\\u82e5\\u4e0d\\u4f20\\u9012\\u6b64\\u53c2\\u6570\\u5219\\u4e3a\\u6240\\u6709\\u5206\\u7c7b"}]', '', 0, 0, 0, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "data": {\r\n "total": 9,\r\n "per_page": "10",\r\n "current_page": 1,\r\n "last_page": 1,\r\n "data": [\r\n {\r\n "id": 16,\r\n "name": "11111111",\r\n "category_id": 2,\r\n "describe": "22222222",\r\n "create_time": "2017-08-07 13:58:37"\r\n },\r\n {\r\n "id": 15,\r\n "name": "tttttt",\r\n "category_id": 1,\r\n "describe": "sddd",\r\n "create_time": "2017-08-07 13:24:46"\r\n }\r\n ]\r\n }\r\n}', 0, 0, 1, 1, 1, 1504779780, 1520504982),

(189, '首页接口', 45, 0, 'combination/index', '首页聚合接口', '', 1, '[{"field_name":"category_id","data_type":"0","is_require":"0","field_describe":"\\u6587\\u7ae0\\u5206\\u7c7bID"}]', '[{"field_name":"article_category_list","data_type":"2","field_describe":"\\u6587\\u7ae0\\u5206\\u7c7b\\u6570\\u636e"},{"field_name":"article_list","data_type":"2","field_describe":"\\u6587\\u7ae0\\u6570\\u636e"}]', 1, 0, 1, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "data": {\r\n "article_category_list": [\r\n {\r\n "id": 2,\r\n "name": "测试文章分类2"\r\n },\r\n {\r\n "id": 1,\r\n "name": "测试文章分类1"\r\n }\r\n ],\r\n "article_list": {\r\n "total": 8,\r\n "per_page": "2",\r\n "current_page": "1",\r\n "last_page": 4,\r\n "data": [\r\n {\r\n "id": 15,\r\n "name": "tttttt",\r\n "category_id": 1,\r\n "describe": "sddd",\r\n "create_time": "2017-08-07 13:24:46"\r\n },\r\n {\r\n "id": 14,\r\n "name": "1111111111111111111",\r\n "category_id": 1,\r\n "describe": "123123",\r\n "create_time": "2017-08-04 15:37:20"\r\n }\r\n ]\r\n }\r\n }\r\n}', 0, 0, 1, 0, 1, 1504785072, 1520504982),

(190, '详情页接口', 45, 0, 'combination/details', '详情页接口', '', 1, '[{"field_name":"article_id","data_type":"0","is_require":"1","field_describe":"\\u6587\\u7ae0ID"}]', '[{"field_name":"article_category_list","data_type":"2","field_describe":"\\u6587\\u7ae0\\u5206\\u7c7b\\u6570\\u636e"},{"field_name":"article_details","data_type":"2","field_describe":"\\u6587\\u7ae0\\u8be6\\u60c5\\u6570\\u636e"}]', 1, 0, 0, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "data": {\r\n "article_category_list": [\r\n {\r\n "id": 2,\r\n "name": "测试文章分类2"\r\n },\r\n {\r\n "id": 1,\r\n "name": "测试文章分类1"\r\n }\r\n ],\r\n "article_details": {\r\n "id": 1,\r\n "name": "213",\r\n "category_id": 1,\r\n "describe": "test001",\r\n "content": "第三方发送到""",\r\n "create_time": "2014-07-22 11:56:53"\r\n }\r\n }\r\n}', 0, 0, 0, 0, 1, 1504922092, 1520504982),

(191, '修改密码', 34, 0, 'common/changepassword', '修改密码接口', '', 1, '[{"field_name":"old_password","data_type":"0","is_require":"1","field_describe":"\\u65e7\\u5bc6\\u7801"},{"field_name":"new_password","data_type":"0","is_require":"1","field_describe":"\\u65b0\\u5bc6\\u7801"}]', '', 0, 1, 0, 0, '{\r\n "code": 0,\r\n "msg": "操作成功",\r\n "exe_time": "0.037002"\r\n}', 0, 0, 0, 0, 1, 1504941496, 1520504982);

-- --------------------------------------------------------

--

-- 表的结构 `ob_api_group`

--

CREATE TABLE IF NOT EXISTS `ob_api_group` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` char(120) NOT NULL DEFAULT '' COMMENT 'aip分组名称',

`sort` tinyint(4) unsigned NOT NULL DEFAULT '0',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`create_time` int(11) unsigned NOT NULL DEFAULT '0',

`status` tinyint(1) NOT NULL DEFAULT '1',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='api分组表' AUTO_INCREMENT=72 ;

--

-- 转存表中的数据 `ob_api_group`

--

INSERT INTO `ob_api_group` (`id`, `name`, `sort`, `update_time`, `create_time`, `status`) VALUES

(34, '基础接口', 0, 1504501195, 0, 1),

(44, '文章接口', 1, 1504765319, 1504765319, 1),

(45, '聚合接口', 0, 1504784149, 1504784149, 1);

-- --------------------------------------------------------

--

-- 表的结构 `ob_article`

--

CREATE TABLE IF NOT EXISTS `ob_article` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '文章ID',

`member_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '会员id',

`name` char(40) NOT NULL DEFAULT '' COMMENT '文章名称',

`category_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '文章分类',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '描述',

`content` text NOT NULL COMMENT '文章内容',

`cover_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '封面图片id',

`file_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '文件id',

`img_ids` varchar(200) NOT NULL DEFAULT '',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='文章表' AUTO_INCREMENT=41 ;

--

-- 转存表中的数据 `ob_article`

--

INSERT INTO `ob_article` (`id`, `member_id`, `name`, `category_id`, `describe`, `content`, `cover_id`, `file_id`, `img_ids`, `create_time`, `update_time`, `status`) VALUES

(23, 1, '序言', 7, 'OneBase 是什么?', '<h3 class="line">\r\nThinkPHP -&gt; OneBase -&gt; 产品\r\n</h3>\r\n<p>\r\nOneBase是一个免费开源的,快速、简单的面向对象的应用研发架构,是为了快速研发应用而诞生的。在保持出色的性能和新颖设计思想同时,也注重易用性。遵循Apache2开源许可协议发布,意味着你可以免费使用OneBase,允许把您基于OneBase研发的应用开源或商业产品发布/销售。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n主要特性\r\n</h3>\r\n<p>\r\n<strong>规范</strong>: OneBase 提供一套编码规范,可使团队研发协作事半功倍。<br />\r\n<strong>严谨</strong>: 异常严谨的错误检测和安全机制,详细的日志信息,为您的研发保驾护航。<br />\r\n<strong>灵活</strong>: 分层,服务,插件等合理的解耦合设计使您升级框架或需求变更得心应手。<br />\r\n<strong>接口</strong>: 完善的接口研发架构,使您只需关注业务逻辑研发,省心省力。<br />\r\n<strong>高效</strong>: 自动缓存设计,抛弃了处处判断的尴尬,使您不知不觉中已经使用了缓存。<br />\r\n<strong>特色</strong>: 无限级权限控制,垃圾资源回收,系统通用回收站,SEO变量支持,性能与操作监控,等各种脑洞大开的设计思想。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n捐赠我们\r\n</h3>\r\n<p>\r\nOneBase致力于简化企业和个人应用研发,您的帮助是对我们最大的支持和动力!\r\n</p>\r\n<p>\r\nOneBase团队一直在坚持不懈地努力,并坚持开源和免费提供使用,帮助开发人员更加方便的进行应用快速研发,如果您对我们的成果表示认同并且觉得对您有所帮助我们愿意接受来自各方面的捐赠^_^。\r\n</p>\r\n<p>\r\n************ <strong>微信捐赠</strong> ************************* <strong>支付宝捐赠</strong> ************\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/6640ec28b9701a85b8a970e53b870da3_265x265.png" alt="" /><img src="https://box.kancloud.cn/b63395ec098a6e3c823825167bd6ffd7_265x265.png" alt="" /><br />\r\n************************* <strong>QQ交流群:477824874</strong> *********************\r\n</p>', 0, 0, '', 1509620805, 1509762405, 1),

(24, 1, '安装OneBase', 7, 'OneBase安装环境要求', '<h1 class="line">\r\nOneBase安装环境要求\r\n</h1>\r\n<hr />\r\n<pre>PHP &gt;= <span class="hljs-number">7.0</span><span class="hljs-number">.0</span> PDO PHP <span class="hljs-keyword">Extension</span> MBstring PHP <span class="hljs-keyword">Extension</span> CURL PHP <span class="hljs-keyword">Extension</span> </pre>\r\n<hr />\r\n<h3 class="line">\r\n开始安装\r\n</h3>\r\n<p>\r\n<strong>下载源码</strong>:<a href="https://gitee.com/Bigotry/OneBase">https://gitee.com/Bigotry/OneBase</a> \r\n</p>\r\n<p>\r\n1.下载源码后解压至Web目录。<br />\r\n2.配置虚拟主机指向源码public目录。<br />\r\n3.一切就绪后访问域名会看到引导安装界面。\r\n</p>\r\n<p>\r\n若安装流程正常执行完毕会跳转至系统首页,此时OneBase已经安装完成啦 ^_^\r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<strong>常见安装问题:</strong> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<strong>1. No input file specified</strong> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<strong>解决办法 (.htaccess 文件 RewriteRule 改成这句 ^(.*)$ index.php [L,E=PATH_INFO:$1])</strong> \r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p>\r\n<strong>2. 某些Nginx版本下出现,控制器不存在问题,参考以下配置文件</strong> \r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p>\r\n<img src="/upload/picture/20171206/a770f61efb2ce03d85bb4bff7a8c70d7.png" alt="" />\r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p>\r\n演示系统配置文件参考 <a href="https://www.kancloud.cn/onebase/onebase/441504">https://www.kancloud.cn/onebase/onebase/441504</a> \r\n</p>\r\n<p>\r\n<br />\r\n</p>\r\n<p>\r\n<span id="__kindeditor_bookmark_start_0__"></span> \r\n</p>', 0, 0, '', 1509762474, 1512538659, 1),

(25, 1, '研发规范', 7, '团队研发事半功倍', '<h1 class="line">\r\n研发规范\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n目录和文件命名\r\n</h3>\r\n<ul>\r\n<li>\r\n目录命令使用小写加下划线。\r\n</li>\r\n<li>\r\n类库、函数文件统一以.php为后缀。\r\n</li>\r\n<li>\r\n类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致。\r\n</li>\r\n<li>\r\n类文件采用驼峰法命名(首字母大写),其它文件采用小写加下划线命名。\r\n</li>\r\n<li>\r\n类名和类文件名保持一致,统一采用驼峰法命名(首字母大写)。\r\n</li>\r\n</ul>\r\n<hr />\r\n<h3 class="line">\r\n函数和类、属性命名\r\n</h3>\r\n<ul>\r\n<li>\r\n类的命名采用驼峰法(首字母大写),例如 User。\r\n</li>\r\n<li>\r\n函数的命名使用小写字母和下划线(小写字母开头)的方式,例如 get_client_ip。\r\n</li>\r\n<li>\r\n方法的命名使用驼峰法(首字母小写),例如 getUserName。\r\n</li>\r\n<li>\r\n属性的命名使用驼峰法(首字母小写),例如 tableName、instance。\r\n</li>\r\n<li>\r\n类名和类文件名保持一致,统一采用驼峰法命名(首字母大写)。\r\n</li>\r\n</ul>\r\n<hr />\r\n<h3 class="line">\r\n常量和配置命名\r\n</h3>\r\n<ul>\r\n<li>\r\n常量以大写字母和下划线命名,例如 APP_PATH。\r\n</li>\r\n<li>\r\n配置参数以小写字母和下划线命名,例如 url_route_on。\r\n</li>\r\n</ul>\r\n<hr />\r\n<h3 class="line">\r\n数据表和字段命名\r\n</h3>\r\n<ul>\r\n<li>\r\n数据表和字段采用小写加下划线方式命名,并注意字段名不要以下划线开头,例如 think_user 表和 user_name字段,不建议使用驼峰和中文作为数据表字段命名。\r\n</li>\r\n</ul>\r\n<hr />\r\n<h3 class="line">\r\n编码建议\r\n</h3>\r\n<ul>\r\n<li>\r\n每个类(不含注释)代码应在200行以内,每个方法(不含注释)代码应在20行以内。\r\n</li>\r\n<li>\r\n控制器层(controller)中,尽量不出现 if else switch 等流程分支语句。\r\n</li>\r\n<li>\r\n业务逻辑尽量封装在逻辑层(logic)中,供控制器调用。\r\n</li>\r\n<li>\r\n数据模型层(model)尽量在逻辑层 logic 中使用,尽量不要再控制器中直接使用model。\r\n</li>\r\n<li>\r\n数据验证尽量写在验证层(validate)中,供逻辑层调用,尽量不要在控制器中进行数据验证。\r\n</li>\r\n<li>\r\n支付|短信 等尽量封装为服务便于后续扩展,图标选择|省市县联动 等尽量封装为插件便于后续复用。\r\n</li>\r\n<li>\r\nAPI接口尽量根据APP界面实现组合接口,减少APP接口请求。\r\n</li>\r\n<li>\r\n其他文档中遗漏项,尽量参考OneBase编码与命名。\r\n</li>\r\n</ul>', 0, 0, '', 1509762507, 1509763729, 1),

(26, 1, '目录结构', 7, 'OneBase目录结构', '<img src="/upload/picture/20171206/e49c32fb18c336cf8706e81c704e6774.png" alt="" /><br />', 0, 0, '', 1509762529, 1512538717, 1),

(27, 1, '首页介绍', 8, '后台登录与首页介绍', '<h3 class="line">\r\n后台首页\r\n</h3>\r\n<p>\r\n安装完成以后输入 <a href="http://xn--eqrt2g04jtsx/admin.php">http://您的域名/admin.php</a> 即可进入后台页面,若没有登录则会跳转登录页面。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/fcea4ef525c3d80d03acf8c94e4149f8_1920x1000.png" alt="" />\r\n</p>\r\n<p>\r\n登录完成后即可进入后台首页\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/8f67981df66d26204af877e920d7e15a_1920x1002.png" alt="" />\r\n</p>\r\n<p>\r\n后台分四个区域 顶部,左侧,内容,底部。\r\n</p>\r\n<p>\r\n<strong>顶部</strong>:左侧为产品名称,旁边小图标可控制左侧是否展开,顶部右侧齿轮按钮可设置后台皮肤与布局,点击昵称区域可显示上次登录时间,时间下方左侧为 清空系统缓存按钮,右侧为退出系统按钮。\r\n</p>\r\n<p>\r\n<strong>左侧</strong>:左侧为系统的菜单区域,左侧菜单为无限级菜单,后台的菜单管理中可控制左侧菜单与上面的图标和链接。\r\n</p>\r\n<p>\r\n<strong>内容</strong>:内容区域分左右布局,左侧为系统信息,显示了系统的版本与依赖框架的版本包括运行环境,右侧为产品信息,值得注意的是右侧下方两项,缓存量与命中率只有后台开启自动缓存的情况下才会统计,缓存量是自动缓存的key数量,命中率为\r\n 查询次数与读取缓存次数计算出来的,比如 查询了 2次,第一次查询了数据库,第二次直接从缓存中读取,那么命中率为50%。<br />\r\n系统信息与产品信息上方左侧为当前操作的标题信息,默认读取菜单名称,也可以控制器中使用 setTitle 方法设置,右侧为面包屑,可标识当前页面的位置结构。\r\n</p>\r\n<p>\r\n<strong>底部</strong>:底部分左右布局,左侧为OneBase的版权信息,右侧为版本号,浮动在右下角的是TP5的调试信息,可在配置文件中关闭,研发阶段建议开启。\r\n</p>', 0, 0, '', 1509792865, 1509792865, 1),

(28, 1, '会员管理', 8, '会员管理及无限级权限介绍', '<h1 class="line">\r\n会员管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n会员列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/98ae6e56979ef99082e34b3855c2d2b8_1920x1005.png" alt="" />\r\n</p>\r\n<p>\r\nOneBase的会员列表是带继承关系的,超级管理员查看可看到所有的会员数据,上方有两个按钮,新增与导出,导出功能为演示系统导出功能的用法,数据列表中的操作按钮有授权与删除,授权可设置会员所在权限组,删除为软删除,需要彻底删除后面介绍回收站时会讲解。\r\n</p>\r\n<p>\r\n<strong>注意</strong>:新增会员时表单中有一项 “是否共享会员”, 若选择共享会员自己的会员则会继承给添加的会员,添加的会员就可以在会员列表中查看到自己的会员数据,若不共享则添加的会员就没有权限查看自己的会员数据。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n权限管理\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/ab02d0de03680b08ff9bf439608836e1_1903x945.png" alt="" />\r\n</p>\r\n<p>\r\n权限管理点开默认为权限组列表页,可新增,删除,编辑 权限组信息。\r\n</p>\r\n<p>\r\n<strong>注意</strong>:每个会员的权限组都是独立的,菜单授权功能也是带继承关系的,超级管理员拥有所有添加在菜单中的节点权限,比如:超级管理员添加\r\n 权限组 A, 并设置权限组A的菜单权限为 a1 a2 a3 a4 a5,然后添加一个会员 张三,将张三授权到权限组 A \r\n中,张三登录进来后,点击权限管理 是看不到 超级管理员的权限组信息的,张三此时可添加自己的权限组 B,然后给 B权限组设置 菜单权限,此时 \r\n张三可设置的菜单节点为 A 组 的最大权限 a1 a2 a3 a4 a5,那么 张三给B组的菜单权限设置为 a1 a2 a3权限, \r\n并添加李四进B组,李四 添加自己的权限组,可分配的最大权限即为 a1 a2 a3,OneBase的权限是可以这样无限的继承分配下去 ^_^。\r\n</p>', 0, 0, '', 1509792935, 1509792935, 1),

(29, 1, '系统设置与配置管理', 8, '设置系统中需要使用的信息,在系统中通过 config 函数取值使用', '<h1 class="line" style="font-size:2.25em;font-family:&quot;font-weight:200;color:rgba(0, 0, 0, 0.87);font-style:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n系统设置与配置管理\r\n</h1>\r\n<hr />\r\n<h3 class="line" style="font-family:&quot;font-weight:200;font-size:1.5em;color:rgba(0, 0, 0, 0.87);font-style:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n系统设置\r\n</h3>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/1bf57e33aa50f1a5ced8cb49638a20fa_1920x947.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n系统设置是设置系统中需要使用的字符串,数组,文本 等信息,在系统中通过 config 函数取值使用。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\nOneBase 默认支持 数字,字符,文本,枚举,数组 5种配置类型,如有需要可自行扩展,后续手册中也会演示扩展配置类型的教程。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n系统设置值之前需要先添加系统配置,下面看下如何添加系统配置。\r\n</p>\r\n<hr />\r\n<h3 class="line" style="font-family:&quot;font-weight:200;font-size:1.5em;color:rgba(0, 0, 0, 0.87);font-style:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n配置列表与配置新增\r\n</h3>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/f993980d47992aee3b1bb7aafa079243_1917x945.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/2aa1a9ed50c0b7c1dbe093adaceb09a2_1918x943.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<strong>注意</strong>:系统设置与配置列表 上面的 基础,数据,系统,API 四项 也属于系统配置,在配置列表中是可以找到的,若需要添加新的配置分组可直接在系统设置中进行设置。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n下面咱们演示添加一个枚举与一个字符配置\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n添加一个客服电话字符配置\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/c6a21953d9548a2e588c25e02736454d_1920x730.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n添加一个语言枚举配置\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/92d4f8fbeb0dadd88ddc5cbb325210f7_1919x811.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n添加了两个配置后,咱们来看一下系统设置。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/461df4a992ddd491056d49afc03a0fce_1917x820.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n发现多出了 两个设置选项,显示顺序可在添加配置时根据排序值控制,这里不再叙述。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n客服电话 是字符类型的配置,所以设置时 可以直接输入字符串值。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n枚举类型是单选择框只能选择一个值,因为咱们添加时配置值默认输入的是0,所以此时默认的是 PHP,默认选择值也就是 配置项 中 冒号 : 之前的内容,注意冒号是英文冒号,前后值不要包含空格,一个选项独占一行。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n下面咱们看看 在程序中如何使用\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/e6c3550fc71329855a9f53f3165c78fc_722x599.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n在代码中咱们通过 config函数获取了 刚才的配置标识对应的值,下面看下输出结果。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n<img src="https://box.kancloud.cn/b28fb82d6ec4f7cf59e5c13754431310_692x111.png" alt="" style="border:0px;" /> \r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n输出了 刚才配置的客服电话 与 语言选项,若咱们在设置中将 客服电话修改为 18521353332 将 语言选项设置为 C#,那么 输出结果将变成 18521353332 与 2 。\r\n</p>\r\n<p style="color:rgba(0, 0, 0, 0.87);font-family:&quot;font-size:15.96px;font-style:normal;font-weight:normal;text-align:start;text-indent:0px;background-color:#FFFFFF;">\r\n^_^。 理解了吧,是不是很简单。 至于OneBase默认自带的配置 后续章节会介绍蛤~\r\n</p>', 0, 0, '', 1509966353, 1509966399, 1),

(30, 1, '菜单管理', 8, 'OneBase 后台菜单是无限级的,意味着您的后台菜单可以无限制的往下层添加', '<h1 class="line">\r\n菜单管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n菜单列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/cae5ec29ba13bd71a1db0aaab597481c_1919x942.png" alt="" /> \r\n</p>\r\n<p>\r\nOneBase 后台菜单是无限级的,意味着您的后台菜单可以无限制的往下层添加。\r\n</p>\r\n<p>\r\n后台查看下级菜单可点击菜单名称或右侧子菜单按钮,此处使用的是递归遍历,所以点进去后模板与外层模板是一样的。\r\n</p>\r\n<p>\r\n初学者添加后台菜单建议参考OneBase现有的菜单数据添加。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n菜单添加\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/8e68f8eec7b630965f564095edf30820_1905x666.png" alt="" /> \r\n</p>\r\n<p>\r\n菜单名称是用于后台显示的和用户识别的,排序值是控制菜单后台显示顺序的(同级有效),链接是指点击菜单后跳转的页面语法(控制器/方法),上级菜单是指当前添加菜单属于某个菜单下级,是否隐藏是控制是否出现在后台菜单中的(隐藏菜单也会进行权限验证),图标是后台菜单名称前面的小图标,此处小图标选择已经封装成了插件需要使用小图标选择时参考菜单添加与编辑这里,小图标库也可以进行扩展(参考\r\n font-awesome)。\r\n</p>', 0, 0, '', 1510137834, 1510137842, 1),

(31, 1, '系统回收站', 8, 'OneBase 的回收站不是其他产品那种 某个表(如:订单或文章)的回收站喔,而是整个系统所有数据的回收站喔~', '<h1 class="line">\r\n系统回收站\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n回收站\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/1025ac572b017963b83ad26b9c6cb517_1914x699.png" alt="" />\r\n</p>\r\n<p>\r\nOneBase 的回收站不是其他产品那种 某个表(如:订单或文章)的回收站喔,而是整个系统所有数据的回收站喔~\r\n</p>\r\n<p>\r\n下面咱们介绍一下回收站列表页面,上图中 第一列是 数据模型名称,第二列是 数据模型路径,第三列是指 此模型下面被删除数据的数量,第四列是操作列,点击数据可查看此模型被删除的数据。\r\n</p>\r\n<p>\r\n小伙伴们看到这里有列表 但是没有新增是不是很好奇数据从哪里来的丫 ^_^。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/058e92152bfb5296e58bf16c663fdb96_1918x783.png" alt="" />\r\n</p>\r\n<p>\r\n就是这里。。系统设置里面的系统分组中有个回收站配置,key为模型名称,值为显示列。\r\n</p>\r\n<p>\r\n意思就是 冒号前面是 模型的名称 如:用户模型(Member),冒号后面是 回收站数据 页面中显示的名称。\r\n</p>\r\n<p>\r\n腻害吧,在这里配置完成后 咱们的回收站就会自动显示对应的模型,查看被删除的数据,还可以还原和彻底干掉喔~\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n回收站数据\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/ee37aaf33b7b5080c2fcfe7a6365a1de_1918x698.png" alt="" />\r\n</p>\r\n<p>\r\n比如上图中就是点击菜单模型旁边的数据看到的页面,里面这些数据 都是被删除的数据,点击彻底删除就可以彻底的让Ta消失。。再也找不回来了。所以要慎重(⊙o⊙)… ,点击恢复正常 可以 把删除状态恢复为正常数据状态,在菜单管理中就可以看到啦。\r\n</p>\r\n<p>\r\n系统回收站就介绍到这里咯,还有疑问可加入QQ交流群:477824874 交流蛤~期待您的光临。\r\n</p>', 0, 0, '', 1510218109, 1510218109, 1),

(32, 1, '服务管理', 8, 'OneBase 已经集成了 支付服务和云存储服务,OneBase 追求的不是服务有多少,插件有多少,而是给开发者们一套可扩展性强,适合用来二次研发的架构', '<h1 class="line">\r\n服务管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n系统服务列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/05df6205da557c801dd1d061d27317a9_1917x650.png" alt="" />\r\n</p>\r\n<p>\r\n图中可以看到OneBase 已经集成了 支付服务和云存储服务,OneBase \r\n追求的不是服务有多少,插件有多少,而是给开发者们一套可扩展性强,适合用来二次研发的架构,所以OneBase 自带的服务、驱动、插件 \r\n主要是起一个引导作用,实际研发中根据实际情况分析,然后进行服务、驱动、插件、函数 等封装。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n服务驱动列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/75855cf08e4d06f5b94ac91fd278cc97_1915x679.png" alt="" />\r\n</p>\r\n<p>\r\n点开支付服务右侧的驱动,可以看到已经存在支付宝、微信支付、易宝支付 的驱动,由此处就可以看到 想扩展其他支付驱动很方便,至于服务和驱动 如果进行编码及研发,可参考后续章节的服务研发及使用。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/46d13fa1b8d41e0f5596932434a78ad4_1915x731.png" alt="" />\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/68456ee3cee2ebedb4a9b86a571ccdc1_1915x736.png" alt="" />\r\n</p>\r\n<p>\r\n上图为 点开 微信驱动安装与支付宝驱动安装的效果,细心的小伙伴会发现 浏览器上的URL并没有变化,而是参数在变化。\r\n</p>\r\n<p>\r\n此处使用了多态性的设计,使不同的驱动安装 展示不同的表单录入项,至于需要录入的录入项则是由驱动研发时进行控制的。\r\n</p>\r\n<p>\r\n这里只是介绍,具体研发及扩展 请阅读后续章节蛤。^_^。\r\n</p>', 0, 0, '', 1510307288, 1510307288, 1),

(33, 1, '插件管理', 8, 'OneBase 可以自己扩展插件哦', '<h1 class="line">\r\n插件管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n钩子列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/232758b9b204a053cd07634fa33a47ce_1918x703.png" alt="" />\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n插件列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/b7406939a59699f894e653fe95eeaf17_1920x737.png" alt="" />\r\n</p>\r\n<p>\r\n上图为 咱们的插件列表,右侧按钮 有 安装 与 卸载,但是每次只会出现一个,未安装状态下出现的是安装按钮,安装状态下出现的是卸载按钮。\r\n</p>', 0, 0, '', 1510393207, 1510393207, 1),

(34, 1, '文章管理', 8, 'OneBase 文章管理可谓简单粗暴', '<h1 class="line">\r\n文章管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n文章分类列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/93e990d2063204f7171aaaee1e8cb319_1915x568.png" alt="" /> \r\n</p>\r\n<p>\r\n文章是很常见的功能模块,也是一套系统经常会操作的功能,所以必须要简单易用。\r\n</p>\r\n<p>\r\nOneBase 考虑到文章编辑人员可能存在使用上的障碍,所以默认使用了最常见的结构,一级文章分类,此处抛弃了 无限级分类的文章架构,因为实际情况下运营人员常常要求很简单,不希望常用功能过于复杂难于理解。\r\n</p>\r\n<p>\r\n当然也不排除有些项目的需求从架构上 就必须要求 多级分类,所以此处谈下 扩展文章分类的做法,OneBase扩展多级分类建议从文章分类上 向上扩展,比如添加文章分类上 加一项顶级分类选择。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n文章列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/e03831ec9865bfa3520b59ff68025fec_1913x688.png" alt="" /> \r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/800dd3be11a94330050a5cb1f3575512_1903x940.png" alt="" /> \r\n</p>\r\n<p>\r\n上图为文章列表与文章编辑, 可以看到列表页和编辑页有些数据是咱们OneBase前端没有看到的数据,OneBase \r\n是一套研发应用解决方案,文章上的 附件,单图上传,多图上传 等 包括其他模块没有用到的一些功能存在是为了展示研发及使用上的技巧,所以 \r\n作为OneBase的使用者,是需要具备二次研发能力的。\r\n</p>', 0, 0, '', 1510393374, 1510393406, 1),

(35, 1, '接口管理', 8, '接口管理看完后再也不用和APP研发工程师撕逼啦~自己去看文档吧,哈哈', '<h1 class="line">\r\n接口管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n接口列表\r\n</h3>\r\n<p>\r\n接口分组管理这里就不在叙述,就是为了给接口归类。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/5f5267b6d4fee4a47c9f7d8e29e88ecc_1919x738.png" alt="" />\r\n</p>\r\n<p>\r\n上图为接口列表页,左上角有两个按钮,一个是新增接口,一个是接口文档跳转按钮。\r\n</p>\r\n<p>\r\n数据列表中 第1列为 接口名称,第2列为接口分组,第3列为接口请求类型,OneBase默认统一POST类型,当然需要其他类型如GET \r\n可自行扩展,第4列为接口地址也就是 \r\n(控制器/方法),第5列是接口目前的状态,接口状态中的选项在系统设置的API栏目下可进行配置,第6列为研发者,研发者成员也在系统设置的API栏目下配置,后面两列为接口排序与操作,接口排序为同级有效。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n接口新增\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/c425bef34644d08f110f9e10e3a794e1_1900x945.png" alt="" />\r\n</p>\r\n<p>\r\n^_^。 虽然表单数据数据有点多,但是不要怕蛤,咱们来一个一个讲解。\r\n</p>\r\n<p>\r\n咱们按从左往右,从上往下进行编号讲解,比如 1 2 3 4 对应的是 接口名称,接口排序值,请求地址,请求类型。\r\n</p>\r\n<p>\r\n1:API接口名称,就是用来看滴。。\r\n</p>\r\n<p>\r\n2:接口排序值,用来进行接口显示排序,这些都很好理解啦。\r\n</p>\r\n<p>\r\n3:请求地址,接口访问地址格式(控制器/方法)。\r\n</p>\r\n<p>\r\n4:请求类型,默认为POST,需要其他类型可自己扩展。\r\n</p>\r\n<p>\r\n5:是否为分页接口,意思就是这个接口是否需要分页功能,如果需要分页功能可传递相关参数,如:list_rows 每页显示的数据量,page 查询的页码。\r\n</p>\r\n<p>\r\n6:研发者,此接口的研发人员,选项中的可选值可在系统设置的API分组下进行配置。\r\n</p>\r\n<p>\r\n7:请求数据,意思就是执行此接口是否需要带请求参数,默认为否不带请求数据,此处的请求数据控制的为接口所依赖的请求参数,大家可以打开 <a href="/api.php">https://onebase.org/api.php</a> 看到里面这些接口 下面有个测试接口功能,此处测试接口功能的表单就是根据这里请求数据设置自动生成的,Token与分页参数是不受此处控制的。\r\n</p>\r\n<p>\r\n8:响应数据,意思就是接口执行成功后返回的数据,默认为否不带返回数据,为是 则可添加接口返回的数据,当然也会有特殊数据 如 分页数据及后面将介绍的数据签名 等。\r\n</p>\r\n<p>\r\n9:接口分组,这个就不介绍啦。\r\n</p>\r\n<p>\r\n10:接口状态,这个也飘过吧。\r\n</p>\r\n<p>\r\n11:接口响应示例,这个是用来给接口调用者看的,方便接口调用者可一眼看清数据结构,提升团队研发效率。\r\n</p>\r\n<p>\r\n12:接口简介,用来看滴。\r\n</p>\r\n<p>\r\n13:是否验证用户令牌:user_token, 用来做身份验证滴,比如 \r\n文章列表接口,所有的访问者不需要登录也可以看到,就设置为否,这样接口调用就不需要带user_token,若 为需要身份验证的接口,如 \r\n订单列表,某个会员只能查看自己的订单,就需要用到user_token啦,所以 像 订单管理,个人中心等 这些接口是需要带 \r\nuser_token的。user_token 是调用登录接口后返回的,所以若终端想调用需要身份验证的接口,则需要 先调用登录接口后将接口中返回的\r\n user_token 保存下来,在后续接口调用过程中使用。\r\n</p>\r\n<p>\r\n14:是否响应数据签名:data_sign,此处是用于做数据安全验证的,比如咱们服务器给终端返回了数据,但是 \r\n终端那边怎么知道真滴是咱们返回的呢。。此时 data_sign 就派上用场啦。 返回的数据中带上了 data_sign \r\n字段,终端根据服务器返回的数据进行与服务器端相同的算法,计算出 终端的 data_sign,然后两端的 data_sign \r\n进行比对,若一模一样,则说明 数据是一模一样滴,这样就很安全啦,别人想改也不行,嘿嘿。\r\n</p>\r\n<p>\r\n15:是否验证请求数据签名:data_sign,原理是一样滴,意思就是 终端像接口提交数据时,咱们服务器端也得知道提交的数据是否安全,所以\r\n 咱们也要根据提交上来的数据 生成 \r\ndata_sign,与提交数据中带的data_sign,进行比对,不一样的话就不执行操作,接口返回数据签名不对,一样的话就放行。\r\n</p>\r\n<p>\r\n16:这个是备用的。。担心服务端人员太腻害,研发出来的接口实在是用言语无法表达。。就可以用富文本进行图文描述。。\r\n</p>\r\n<p>\r\n好啦,输入选项介绍完了,咱们看下登录接口的编辑数据页面,看看是咋输入滴。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/b66298b92545f3cc1b2c22d886a68f4f_1900x947.png" alt="" />\r\n</p>\r\n<p>\r\n后台接口管理功能就介绍到这里,更深一步将在接口研发中讲解。\r\n</p>', 0, 0, '', 1510646369, 1510646369, 1),

(36, 1, '优化维护-SEO管理', 8, 'OneBase中的SEO信息可是支持变量滴~', '<h1 class="line">\r\nSEO管理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\nSEO管理列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/4065235f0baa9f04351aa5dfda0a7590_1920x562.png" alt="" />\r\n</p>\r\n<p>\r\n上图为SEO管理数据列表,可以看到标题和关键词里面有变量,OneBase中的这些变量可不是固定的喔~\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\nSEO变量\r\n</h3>\r\n<p>\r\n至于新增和编辑这里就不在叙述啦~太简单咯,咱们直接看看SEO中的这些变量是从哪里来滴。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/6f2c5cf3484b2768324f2409ca84accb_1915x786.png" alt="" />\r\n</p>\r\n<p>\r\n咱们点开首页的SEO配置信息编辑页面,看到里面用到这些变量,{$category_name},{$article_title},{$article_describe}\r\n</p>\r\n<p>\r\n这些变量是从哪里来的? 请看下图\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/a805e5dee7706276a304787f2ee31194_1031x930.png" alt="" />\r\n</p>\r\n<p>\r\n细心的观众能看出来,都是 assign 方法中的变量,如果 assign 不知道是干啥的。。那么请移步至ThinkPHP5的手册 看完再来蛤。。\r\n</p>\r\n<p>\r\nSEO中的变量支持 所有在控制器中 assign 给模板赋值的变量,这意味着您想添加或减少很简单。。前提是您是开发者。当然,开发者开发完成后建议把此处所支持的变量录入到 可用变量 的输入框中 方便 非开发者知道可支持的有哪些变量蛤。\r\n</p>', 0, 0, '', 1512096686, 1512096686, 1),

(37, 1, '优化维护-数据库', 8, '此处可以备份和还原数据库', '<h1 class="line">\r\n数据库\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n数据备份\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/fca84a3b960b8d65dfe2896bab3de32d_1912x873.png" alt="" />\r\n</p>\r\n<p>\r\n上图是数据备份页面,列表中是数据库表信息,点击左上角的按钮备份数据,可实现数据库的备份,旁边的 优化和修复是执行的MySql内置的优化与修复,如需了解请自行搜索蛤。\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n数据还原\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/a939e0e84d1a25952e619e7beaff76ad_1916x788.png" alt="" />\r\n</p>\r\n<p>\r\n上图是数据还原的界面,列表中为之前备份的记录,点击右侧的还原可还原到当时备份的数据库,若系统已经上线此功能要慎重使用。\r\n</p>', 0, 0, '', 1512096775, 1512096775, 1),

(38, 1, '优化维护-文件清理', 8, '自动清理系统辣鸡文件和辣鸡数据,维护系统健康', '<h1 class="line">\r\n文件清理\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n文件清理列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/2cbbad1d7df01f67406b189a057e4a2a_1918x609.png" alt="" />\r\n</p>\r\n<p>\r\n点击文件清理后发现没有数据,说明系统很健康喔~木有辣鸡文件需要清理,下面咱们人工制造两个无用的图片试试。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/d42b3147c268615b37e5275c57cc5344_561x798.png" alt="" />\r\n</p>\r\n<p>\r\n上图中咱们 制造了 辣鸡1 和 辣鸡2,再来看看后台。\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/ded6f545da29c4ddada686a061e93568_1917x764.png" alt="" />\r\n</p>\r\n<p>\r\n发现辣鸡了。。腻害吧。嘿嘿。\r\n</p>\r\n<p>\r\n然后咱们点击开始清理,然后就会自动干掉 系统中没有引用的文件,这里不光是干掉没有使用的辣鸡文件哦,还隐式的干掉了 数据库中记录的文件记录但是在文件中又不存在的,是双向检索蛤。\r\n</p>\r\n<p>\r\n那么问题来了, 系统怎么知道咱们哪些需要检索为辣鸡数据 哪些不需要检索呢?\r\n</p>\r\n<p>\r\n<img src="https://box.kancloud.cn/0e48380b13dda40e59223ed21ab18d05_1918x845.png" alt="" />\r\n</p>\r\n<p>\r\n图上就是配置检索字段的地方啦。: 冒号前面为 模型名称,后面为 需要检索的字段名称,但是 \r\n冒号前面的模型前咋还有下划线呢?下划线是用来区分key标识的,因为 如果没有下划线前面的 0 和 1 系统就没办法知道 这两个 key \r\n有啥区别,就理解成了 只有 1个key , 就会造成系统清理的时候 有遗漏蛤,所以 需要添加清理配置列就参考此处喔。\r\n</p>', 0, 0, '', 1512096869, 1512096869, 1),

(39, 1, '优化维护-行为日志', 8, '后台操作行为一目了然', '<h3 class="line">\r\n行为日志列表\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/ace534fc77ad7137c1eb21c2679d287b_1917x855.png" alt="" /> \r\n</p>\r\n<p>\r\n图上是系统的行为日志,此处的行为日志是指后台的操作行为记录,不涉及其他模块,后台研发过程中需要记录行为日志则使用 action_log 函数记录,清空与删除日志此处就不说啦。\r\n</p>', 0, 0, '', 1512471084, 1512471100, 1),

(40, 1, '优化维护-执行记录', 8, '监控系统执行记录,让系统随时处于最佳状态', '<h1 class="line">\r\n执行记录\r\n</h1>\r\n<hr />\r\n<h3 class="line">\r\n全局范围\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/5cbb0f2cb8e55ef6593668299a67022a_1916x732.png" alt="" />\r\n</p>\r\n<hr />\r\n<h3 class="line">\r\n接口范围\r\n</h3>\r\n<p>\r\n<img src="https://box.kancloud.cn/10f2ec0dfb638c81b70016e7359c51ac_1914x725.png" alt="" />\r\n</p>\r\n<hr />\r\n<p>\r\n这功能就有点腻害啦,是压轴滴蛤。\r\n</p>\r\n<p>\r\n咱们第一张图是 全局范围,意思就是 咱们整套系统的任何模块所有的操作记录。\r\n</p>\r\n<p>\r\n第二张图是 接口范围,意思就是 咱们接口模块所有的执行操作记录。\r\n</p>\r\n<p>\r\n至于数据列表上面的列就不介绍啦~相信能来到这里的小伙伴都可以看懂喔。\r\n</p>\r\n<p>\r\n看到全局范围 1200多页。。。会不会影响系统速度呢?\r\n</p>\r\n<p>\r\n看看咱们执行记录的流程就知道咯\r\n</p>\r\n<p>\r\n1.访问系统 -&gt; 2.记录文件 -&gt; 3.后台手动批量入库 -&gt; 4.干掉已入库文件记录\r\n</p>\r\n<p>\r\n清空日志是指软删除咱们全局范围中所有的数据库记录,全局范围包含了接口范围喔~\r\n</p>\r\n<p>\r\n之前就说过咯,咱们所有的数据删除都是软删除,想要彻底干掉就去回收站介绍里面看看蛤。\r\n</p>\r\n<p>\r\n咱们后台功能介绍就到此为止咯,相信童鞋们已经看到OneBase的腻害之处了吧,下面咱们来看看如何研发后台功能吧。 ^_^。\r\n</p>', 0, 0, '', 1512471194, 1512471194, 1);

-- --------------------------------------------------------

--

-- 表的结构 `ob_article_category`

--

CREATE TABLE IF NOT EXISTS `ob_article_category` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '分类ID',

`name` varchar(30) NOT NULL DEFAULT '' COMMENT '分类名称',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '描述',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`icon` char(20) NOT NULL DEFAULT '' COMMENT '分类图标',

PRIMARY KEY (`id`),

UNIQUE KEY `uk_name` (`name`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='分类表' AUTO_INCREMENT=9 ;

--

-- 转存表中的数据 `ob_article_category`

--

INSERT INTO `ob_article_category` (`id`, `name`, `describe`, `create_time`, `update_time`, `status`, `icon`) VALUES

(7, '基础', '基础内容', 1509620712, 1509620712, 1, 'fa-street-view'),

(8, '后台介绍', '后台功能介绍', 1509792822, 1509792822, 1, 'fa-user');

-- --------------------------------------------------------

--

-- 表的结构 `ob_auth_group`

--

CREATE TABLE IF NOT EXISTS `ob_auth_group` (

`id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户组id,自增主键',

`module` varchar(20) NOT NULL DEFAULT '' COMMENT '用户组所属模块',

`name` char(30) NOT NULL DEFAULT '' COMMENT '用户组名称',

`describe` varchar(80) NOT NULL DEFAULT '' COMMENT '描述信息',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '用户组状态:为1正常,为0禁用,-1为删除',

`rules` varchar(1000) NOT NULL DEFAULT '' COMMENT '用户组拥有的规则id,多个规则 , 隔开',

`member_id` int(10) unsigned NOT NULL DEFAULT '0',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`create_time` int(11) unsigned NOT NULL DEFAULT '0',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='权限组表' AUTO_INCREMENT=18 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_auth_group_access`

--

CREATE TABLE IF NOT EXISTS `ob_auth_group_access` (

`member_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户id',

`group_id` mediumint(8) unsigned NOT NULL DEFAULT '0' COMMENT '用户组id',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`create_time` int(11) unsigned NOT NULL DEFAULT '0',

`status` tinyint(1) unsigned NOT NULL DEFAULT '1'

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户组授权表';

-- --------------------------------------------------------

--

-- 表的结构 `ob_blogroll`

--

CREATE TABLE IF NOT EXISTS `ob_blogroll` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`name` char(50) NOT NULL DEFAULT '' COMMENT '链接名称',

`img_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '链接图片封面',

`url` varchar(255) NOT NULL DEFAULT '' COMMENT '链接地址',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '描述',

`sort` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '排序',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='友情链接表' AUTO_INCREMENT=3 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_config`

--

CREATE TABLE IF NOT EXISTS `ob_config` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '配置ID',

`name` varchar(30) NOT NULL DEFAULT '' COMMENT '配置名称',

`type` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '配置类型',

`title` varchar(50) NOT NULL DEFAULT '' COMMENT '配置标题',

`group` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '配置分组',

`extra` varchar(255) NOT NULL DEFAULT '' COMMENT '配置选项',

`describe` varchar(255) NOT NULL DEFAULT '' COMMENT '配置说明',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',

`value` text NOT NULL COMMENT '配置值',

`sort` smallint(3) unsigned NOT NULL DEFAULT '0' COMMENT '排序',

PRIMARY KEY (`id`),

UNIQUE KEY `uk_name` (`name`),

KEY `type` (`type`),

KEY `group` (`group`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='配置表' AUTO_INCREMENT=67 ;

--

-- 转存表中的数据 `ob_config`

--

INSERT INTO `ob_config` (`id`, `name`, `type`, `title`, `group`, `extra`, `describe`, `create_time`, `update_time`, `status`, `value`, `sort`) VALUES

(1, 'seo_title', 1, '网站标题', 1, '', '网站标题前台显示标题,优先级低于SEO模块', 1378898976, 1512555314, 1, 'OneBase免费开源架构', 3),

(2, 'seo_description', 2, '网站描述', 1, '', '网站搜索引擎描述,优先级低于SEO模块', 1378898976, 1512555314, 1, 'OneBase|ThinkPHP5', 100),

(3, 'seo_keywords', 2, '网站关键字', 1, '', '网站搜索引擎关键字,优先级低于SEO模块', 1378898976, 1512555314, 1, 'OneBase|ThinkPHP5', 99),

(9, 'config_type_list', 3, '配置类型列表', 3, '', '主要用于数据解析和页面表单的生成', 1378898976, 1512982406, 1, '0:数字\r\n1:字符\r\n2:文本\r\n3:数组\r\n4:枚举\r\n5:图片\r\n6:文件\r\n7:富文本\r\n8:单选\r\n9:多选\r\n10:日期\r\n11:时间\r\n12:颜色', 100),

(20, 'config_group_list', 3, '配置分组', 3, '', '配置分组', 1379228036, 1512982406, 1, '1:基础\r\n2:数据\r\n3:系统\r\n4:API', 100),

(25, 'list_rows', 0, '每页数据记录数', 2, '', '数据每页显示记录数', 1379503896, 1507197630, 1, '10', 10),

(29, 'data_backup_part_size', 0, '数据库备份卷大小', 2, '', '该值用于限制压缩后的分卷最大长度。单位:B', 1381482488, 1507197630, 1, '52428800', 7),

(30, 'data_backup_compress', 4, '数据库备份文件是否启用压缩', 2, '0:不压缩\r\n1:启用压缩', '压缩备份文件需要PHP环境支持gzopen,gzwrite函数', 1381713345, 1507197630, 1, '1', 9),

(31, 'data_backup_compress_level', 4, '数据库备份文件压缩级别', 2, '1:普通\r\n4:一般\r\n9:最高', '数据库备份文件的压缩级别,该配置在开启压缩时生效', 1381713408, 1507197630, 1, '9', 10),

(33, 'allow_url', 3, '不受权限验证的url', 3, '', '', 1386644047, 1512982406, 1, '0:file/pictureupload\r\n1:addon/execute', 100),

(43, 'empty_list_describe', 1, '数据列表为空时的描述信息', 2, '', '', 1492278127, 1507197630, 1, 'aOh! 暂时还没有数据~', 0),

(44, 'trash_config', 3, '回收站配置', 3, '', 'key为模型名称,值为显示列。', 1492312698, 1512982406, 1, 'Config:name\r\nAuthGroup:name\r\nMember:nickname\r\nMenu:name\r\nArticle:name\r\nArticleCategory:name\r\nAddon:name\r\nPicture:name\r\nFile:name\r\nActionLog:describe\r\nApi:name\r\nApiGroup:name\r\nBlogroll:name', 0),

(49, 'static_domain', 1, '静态资源域名', 1, '', '若静态资源为本地资源则此项为空,若为外部资源则为存放静态资源的域名', 1502430387, 1512555314, 1, '', 0),

(52, 'team_developer', 3, '研发团队人员', 4, '', '', 1504236453, 1510894595, 1, '0:Bigotry\r\n1:扫地僧', 0),

(53, 'api_status_option', 3, 'API接口状态', 4, '', '', 1504242433, 1510894595, 1, '0:待研发\r\n1:研发中\r\n2:测试中\r\n3:已完成', 0),

(54, 'api_data_type_option', 3, 'API数据类型', 4, '', '', 1504328208, 1510894595, 1, '0:字符\r\n1:文本\r\n2:数组\r\n3:文件', 0),

(55, 'frontend_theme', 1, '前端主题', 1, '', '', 1504762360, 1512555314, 1, 'default', 0),

(56, 'api_domain', 1, 'API部署域名', 4, '', '', 1504779094, 1510894595, 1, 'https://demo.onebase.org', 0),

(57, 'api_key', 1, 'API加密KEY', 4, '', '泄露后API将存在安全隐患', 1505302112, 1510894595, 1, 'l2V|gfZp{8`;jzR~6Y1_', 0),

(58, 'loading_icon', 4, '页面Loading图标设置', 1, '1:图标1\r\n2:图标2\r\n3:图标3\r\n4:图标4\r\n5:图标5\r\n6:图标6\r\n7:图标7', '页面Loading图标支持7种图标切换', 1505377202, 1512983062, 1, '7', 80),

(59, 'sys_file_field', 3, '文件字段配置', 3, '', 'key为模型名,值为文件列名。', 1505799386, 1512982406, 1, '0_article:file_id', 0),

(60, 'sys_picture_field', 3, '图片字段配置', 3, '', 'key为模型名,值为图片列名。', 1506315422, 1512982406, 1, '0_article:cover_id\r\n1_article:img_ids', 0),

(61, 'jwt_key', 1, 'JWT加密KEY', 4, '', '', 1506748805, 1510894595, 1, 'l2V|DSFXXXgfZp{8`;FjzR~6Y1_', 0),

(65, 'admin_allow_ip', 3, '超级管理员登录IP', 3, '', '后台超级管理员登录IP限制,其他角色不受限。', 1510995580, 1512982406, 1, '0:27.22.112.250', 0),

(66, 'pjax_mode', 8, 'PJAX模式', 3, '0:否\r\n1:是', '若为PJAX模式则浏览器不会刷新,若为常规模式则为AJAX+刷新', 1512370397, 1512982406, 1, '1', 120);

-- --------------------------------------------------------

--

-- 表的结构 `ob_driver`

--

CREATE TABLE IF NOT EXISTS `ob_driver` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',

`service_name` varchar(40) NOT NULL DEFAULT '' COMMENT '服务标识',

`driver_name` varchar(20) NOT NULL DEFAULT '' COMMENT '驱动标识',

`config` text NOT NULL COMMENT '配置',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '安装时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='插件表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_file`

--

CREATE TABLE IF NOT EXISTS `ob_file` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '文件ID',

`name` varchar(100) NOT NULL DEFAULT '' COMMENT '原始文件名',

`path` varchar(255) NOT NULL DEFAULT '' COMMENT '保存名称',

`url` varchar(255) NOT NULL DEFAULT '' COMMENT '远程地址',

`sha1` char(40) NOT NULL DEFAULT '' COMMENT '文件 sha1编码',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '上传时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`status` tinyint(1) NOT NULL DEFAULT '1',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='文件表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_goods`

--

CREATE TABLE IF NOT EXISTS `ob_goods` (

`g_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '货物编号',

`name` char(50) NOT NULL DEFAULT '' COMMENT '货物名称',

`type` char(5) NOT NULL COMMENT '货物类型',

`g_number` int(11) NOT NULL COMMENT '货物数量',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`g_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='货物管理表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_hook`

--

CREATE TABLE IF NOT EXISTS `ob_hook` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',

`name` varchar(40) NOT NULL DEFAULT '' COMMENT '钩子名称',

`describe` varchar(255) NOT NULL COMMENT '描述',

`addon_list` varchar(255) NOT NULL DEFAULT '' COMMENT '钩子挂载的插件 '',''分割',

`status` tinyint(1) unsigned NOT NULL DEFAULT '1',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='钩子表' AUTO_INCREMENT=40 ;

--

-- 转存表中的数据 `ob_hook`

--

INSERT INTO `ob_hook` (`id`, `name`, `describe`, `addon_list`, `status`, `update_time`, `create_time`) VALUES

(36, 'File', '文件上传钩子', 'File', 1, 0, 0),

(37, 'Icon', '图标选择钩子', 'Icon', 1, 0, 0),

(38, 'ArticleEditor', '富文本编辑器', 'Editor', 1, 0, 0);

-- --------------------------------------------------------

--

-- 表的结构 `ob_into`

--

CREATE TABLE IF NOT EXISTS `ob_into` (

`into_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '入库单号',

`g_id` int(10) NOT NULL COMMENT '货物编号',

`war_id` int(10) NOT NULL COMMENT '仓库编号',

`into_number` int(11) NOT NULL COMMENT '入库数量',

`per_id` int(10) NOT NULL COMMENT '入库员工编号',

`into_time` time NOT NULL COMMENT '入库时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`into_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='友情链接表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_member`

--

CREATE TABLE IF NOT EXISTS `ob_member` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户ID',

`nickname` char(50) NOT NULL DEFAULT '' COMMENT '昵称',

`username` char(16) NOT NULL DEFAULT '' COMMENT '用户名',

`password` char(32) NOT NULL DEFAULT '' COMMENT '密码',

`email` char(32) NOT NULL DEFAULT '' COMMENT '用户邮箱',

`mobile` char(15) NOT NULL DEFAULT '' COMMENT '用户手机',

`update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '注册时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '用户状态',

`leader_id` int(10) unsigned NOT NULL DEFAULT '1' COMMENT '上级会员ID',

`is_share_member` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否共享会员',

`is_inside` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否为后台使用者',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='会员表' AUTO_INCREMENT=967 ;

--

-- 转存表中的数据 `ob_member`

--

INSERT INTO `ob_member` (`id`, `nickname`, `username`, `password`, `email`, `mobile`, `update_time`, `create_time`, `status`, `leader_id`, `is_share_member`, `is_inside`) VALUES

(1, 'admin', 'admin', 'd2f385c0b616b73b9388032303773331', '12345687@qq.com', '18555550710', 1568877790, 1568860104, 1, 0, 0, 1);

-- --------------------------------------------------------

--

-- 表的结构 `ob_menu`

--

CREATE TABLE IF NOT EXISTS `ob_menu` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '文档ID',

`name` varchar(50) NOT NULL DEFAULT '' COMMENT '菜单名称',

`pid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '上级分类ID',

`sort` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '排序(同级有效)',

`module` char(20) NOT NULL DEFAULT '' COMMENT '模块',

`url` char(255) NOT NULL DEFAULT '' COMMENT '链接地址',

`is_hide` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否隐藏',

`is_shortcut` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否快捷操作',

`icon` char(30) NOT NULL DEFAULT '' COMMENT '图标',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`create_time` int(11) unsigned NOT NULL DEFAULT '0',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='菜单表' AUTO_INCREMENT=228 ;

--

-- 转存表中的数据 `ob_menu`

--

INSERT INTO `ob_menu` (`id`, `name`, `pid`, `sort`, `module`, `url`, `is_hide`, `is_shortcut`, `icon`, `status`, `update_time`, `create_time`) VALUES

(1, '系统首页', 0, 1, 'admin', 'index/index', 0, 0, 'fa-home', 1, 1520506753, 0),

(16, '会员管理', 0, 3, 'admin', 'member/index', 0, 0, 'fa-users', 1, 1520506753, 0),

(17, '会员列表', 16, 1, 'admin', 'member/memberlist', 0, 1, 'fa-list', 1, 1495272875, 0),

(18, '会员添加', 16, 2, 'admin', 'member/memberadd', 0, 0, 'fa-user-plus', 1, 1520505510, 0),

(27, '权限管理', 16, 3, 'admin', 'auth/grouplist', 0, 0, 'fa-key', 1, 1520505512, 0),

(32, '权限组编辑', 27, 0, 'admin', 'auth/groupedit', 1, 0, '', 1, 1492002620, 0),

(34, '授权', 27, 0, 'admin', 'auth_manager/group', 1, 0, '', 1, 0, 0),

(35, '菜单授权', 27, 0, 'admin', 'auth/menuauth', 1, 0, '', 1, 1492095653, 0),

(36, '会员授权', 27, 0, 'admin', 'auth_manager/memberaccess', 1, 0, '', 1, 0, 0),

(68, '系统管理', 0, 2, 'admin', 'config/group', 0, 0, 'fa-wrench', 1, 1520506753, 0),

(69, '系统设置', 68, 3, 'admin', 'config/setting', 0, 0, 'fa-cogs', 1, 1520505460, 0),

(70, '配置管理', 68, 2, 'admin', 'config/index', 0, 0, 'fa-cog', 1, 1520505457, 0),

(71, '配置编辑', 70, 0, 'admin', 'config/configedit', 1, 0, '', 1, 1491674180, 0),

(72, '配置删除', 70, 0, 'admin', 'config/configDel', 1, 0, '', 1, 1491674201, 0),

(73, '配置添加', 70, 0, 'admin', 'config/configadd', 0, 0, 'fa-plus', 1, 1491666947, 0),

(75, '菜单管理', 68, 1, 'admin', 'menu/index', 0, 0, 'fa-th-large', 1, 1520505453, 0),

(98, '菜单编辑', 75, 0, 'admin', 'menu/menuedit', 1, 0, '', 1, 1512459021, 0),

(124, '菜单列表', 75, 0, 'admin', 'menu/menulist', 0, 1, 'fa-list', 1, 1491318271, 0),

(125, '菜单添加', 75, 0, 'admin', 'menu/menuadd', 0, 0, 'fa-plus', 1, 1491318307, 0),

(126, '配置列表', 70, 0, 'admin', 'config/configlist', 0, 1, 'fa-list', 1, 1491666890, 1491666890),

(127, '菜单状态', 75, 0, 'admin', 'menu/setstatus', 1, 0, '', 1, 1520506673, 1491674128),

(128, '权限组添加', 27, 0, 'admin', 'auth/groupadd', 1, 0, '', 1, 1492002635, 1492002635),

(134, '授权', 17, 0, 'admin', 'member/memberauth', 1, 0, '', 1, 1492238568, 1492101426),

(135, '回收站', 68, 4, 'admin', 'trash/trashlist', 0, 0, ' fa-recycle', 1, 1520505468, 1492311462),

(136, '回收站数据', 135, 0, 'admin', 'trash/trashdatalist', 1, 0, 'fa-database', 1, 1492319477, 1492319392),

(140, '服务管理', 68, 5, 'admin', 'service/servicelist', 0, 0, 'fa-server', 1, 1520505473, 1492352972),

(141, '插件管理', 68, 6, 'admin', 'addon/index', 0, 0, 'fa-puzzle-piece', 1, 1520505475, 1492427605),

(142, '钩子列表', 141, 0, 'admin', 'addon/hooklist', 0, 0, 'fa-anchor', 1, 1492427665, 1492427665),

(143, '插件列表', 141, 0, 'admin', 'addon/addonlist', 0, 0, 'fa-list', 1, 1492428116, 1492427838),

(144, '文章管理', 0, 4, 'admin', 'article/index', 0, 0, 'fa-edit', 1, 1520506753, 1492480187),

(145, '文章列表', 144, 0, 'admin', 'article/articlelist', 0, 1, 'fa-list', 1, 1492480245, 1492480245),

(146, '文章分类', 144, 0, 'admin', 'article/articlecategorylist', 0, 0, 'fa-list', 1, 1492480359, 1492480342),

(147, '文章分类编辑', 146, 0, 'admin', 'article/articlecategoryedit', 1, 0, '', 1, 1492485294, 1492485294),

(148, '分类添加', 144, 0, 'admin', 'article/articlecategoryadd', 0, 0, 'fa-plus', 1, 1492486590, 1492486576),

(149, '文章添加', 144, 0, 'admin', 'article/articleadd', 0, 0, 'fa-plus', 1, 1492518453, 1492518453),

(150, '文章编辑', 145, 0, 'admin', 'article/articleedit', 1, 0, '', 1, 1492879589, 1492879589),

(151, '插件安装', 143, 0, 'admin', 'addon/addoninstall', 1, 0, '', 1, 1492879763, 1492879763),

(152, '插件卸载', 143, 0, 'admin', 'addon/addonuninstall', 1, 0, '', 1, 1492879789, 1492879789),

(153, '文章删除', 145, 0, 'admin', 'article/articledel', 1, 0, '', 1, 1492879960, 1492879960),

(154, '文章分类删除', 146, 0, 'admin', 'article/articlecategorydel', 1, 0, '', 1, 1492879995, 1492879995),

(156, '驱动安装', 140, 0, 'admin', 'service/driverinstall', 1, 0, '', 1, 1502267009, 1502267009),

(157, '接口管理', 0, 5, 'admin', 'api/index', 0, 0, 'fa fa-book', 1, 1520506753, 1504000434),

(158, '分组管理', 157, 0, 'admin', 'api/apigrouplist', 0, 0, 'fa fa-fw fa-th-list', 1, 1504000977, 1504000723),

(159, '分组添加', 157, 0, 'admin', 'api/apigroupadd', 0, 0, 'fa fa-fw fa-plus', 1, 1504004646, 1504004646),

(160, '分组编辑', 157, 0, 'admin', 'api/apigroupedit', 1, 0, '', 1, 1504004710, 1504004710),

(161, '分组删除', 157, 0, 'admin', 'api/apigroupdel', 1, 0, '', 1, 1504004732, 1504004732),

(162, '接口列表', 157, 0, 'admin', 'api/apilist', 0, 0, 'fa fa-fw fa-th-list', 1, 1504172326, 1504172326),

(163, '接口添加', 157, 0, 'admin', 'api/apiadd', 0, 0, 'fa fa-fw fa-plus', 1, 1504172352, 1504172352),

(164, '接口编辑', 157, 0, 'admin', 'api/apiedit', 1, 0, '', 1, 1504172414, 1504172414),

(165, '接口删除', 157, 0, 'admin', 'api/apidel', 1, 0, '', 1, 1504172435, 1504172435),

(166, '优化维护', 0, 6, 'admin', 'maintain/index', 0, 0, 'fa-legal', 1, 1520506753, 1505387256),

(168, '数据库', 166, 0, 'admin', 'maintain/database', 0, 0, 'fa-database', 1, 1505539670, 1505539394),

(169, '数据备份', 168, 0, 'admin', 'database/databackup', 0, 0, 'fa-download', 1, 1506309900, 1505539428),

(170, '数据还原', 168, 0, 'admin', 'database/datarestore', 0, 0, 'fa-exchange', 1, 1506309911, 1505539492),

(171, '文件清理', 166, 0, 'admin', 'fileclean/cleanlist', 0, 0, 'fa-file', 1, 1506310152, 1505788517),

(174, '行为日志', 166, 0, 'admin', 'log/loglist', 0, 1, 'fa-street-view', 1, 1507201516, 1507200836),

(203, '友情链接', 68, 7, 'admin', 'blogroll/index', 0, 0, 'fa-link', 1, 1520505723, 1520505717),

(204, '链接列表', 203, 0, 'admin', 'blogroll/blogrolllist', 0, 0, 'fa-th', 1, 1520505777, 1520505777),

(205, '链接添加', 203, 0, 'admin', 'blogroll/blogrolladd', 0, 0, 'fa-plus', 1, 1520505826, 1520505826),

(206, '链接编辑', 203, 0, 'admin', 'blogroll/blogrolledit', 1, 0, 'fa-edit', 1, 1520505863, 1520505863),

(207, '链接删除', 203, 0, 'admin', 'blogroll/blogrolldel', 1, 0, 'fa-minus', 1, 1520505889, 1520505889),

(208, '菜单排序', 75, 0, 'admin', 'menu/setsort', 1, 0, '', 1, 1520506696, 1520506696),

(209, '会员编辑', 16, 2, 'admin', 'member/memberedit', 1, 0, 'fa-edit', 1, 1520505510, 0),

(210, '修改密码', 1, 2, 'admin', 'member/editpassword', 1, 0, 'fa-edit', 1, 1520505510, 0),

(211, '仓库管理', 0, 0, 'admin', 'warehouse/index', 0, 0, 'fa-th-list', 1, 0, 1568861472),

(212, '人员管理', 0, 0, 'admin', 'personnel/index', 0, 0, 'fa-th-list', 1, 0, 1568861659),

(213, '出库管理', 211, 1, 'admin', 'warehouse/out', 0, 0, 'fa-th-list', 1, 1568862237, 1568861710),

(214, '入库管理', 211, 2, 'admin', 'warehouse/into', 0, 0, 'fa-th-list', 1, 1568862232, 1568861735),

(215, '商品种类', 211, 3, 'admin', 'warehouse/type', 0, 0, 'fa-th-list', 1, 1568862241, 1568861870),

(216, '库存信息', 211, 4, 'admin', 'warehouse/information', 0, 0, 'fa-th-list', 1, 1568862244, 1568861908),

(217, '库存数量', 216, 0, 'admin', 'information/number', 0, 0, 'fa-th-list', 1, 0, 1568861946),

(218, '盘点库存', 216, 0, 'admin', 'information/Inventory', 0, 0, 'fa-th-list', 1, 0, 1568862026),

(219, '入库清单', 216, 0, 'admin', 'information/into_list', 0, 0, 'fa-th-list', 1, 0, 1568862058),

(220, '出库清单', 216, 0, 'admin', 'information/out_list', 0, 0, 'fa-th-list', 1, 0, 1568862083),

(221, '打印清单', 216, 0, 'admin', 'information/printing', 0, 0, 'fa-th-list', 1, 0, 1568862120),

(222, '增加商品', 215, 1, 'admin', 'type/add', 0, 0, 'fa-th-list', 1, 1568862217, 1568862175),

(223, '删除产品', 215, 2, 'admin', 'type/delete', 0, 0, 'fa-th-list', 1, 1568862220, 1568862210),

(224, '添加账号', 212, 1, 'admin', 'personnel/raise', 0, 0, 'fa-user', 1, 0, 1568862341),

(225, '删除账号', 212, 2, 'admin', 'personnel/cut', 0, 0, 'fa-user', 1, 0, 1568862397),

(226, '个人信息', 212, 3, 'admin', 'personnel/message', 0, 0, 'fa-user', 1, 0, 1568862447),

(227, '人员列表', 212, 0, 'admin', 'personnel/personnellist', 0, 0, 'fa-user', 1, 0, 1568877894);

-- --------------------------------------------------------

--

-- 表的结构 `ob_out`

--

CREATE TABLE IF NOT EXISTS `ob_out` (

`out_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '出库单号',

`g_id` int(10) NOT NULL COMMENT '货物编号',

`war_id` int(10) NOT NULL COMMENT '仓库编号',

`out_number` int(11) NOT NULL COMMENT '出库数量',

`per_id` int(10) NOT NULL COMMENT '出库员工编号',

`out_time` time NOT NULL COMMENT '出库时间',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`out_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='友情链接表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_personnel`

--

CREATE TABLE IF NOT EXISTS `ob_personnel` (

`per_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '员工编号',

`name` char(50) NOT NULL DEFAULT '' COMMENT '员工名称',

`age` int(11) NOT NULL COMMENT '员工年龄',

`password` char(10) NOT NULL COMMENT '员工密码',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`per_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='人员管理表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_picture`

--

CREATE TABLE IF NOT EXISTS `ob_picture` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键id自增',

`name` varchar(255) NOT NULL DEFAULT '' COMMENT '图片名称',

`path` varchar(255) NOT NULL DEFAULT '' COMMENT '路径',

`url` varchar(255) NOT NULL DEFAULT '' COMMENT '图片链接',

`sha1` char(40) NOT NULL DEFAULT '' COMMENT '文件 sha1编码',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='图片表' AUTO_INCREMENT=194 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_stock`

--

CREATE TABLE IF NOT EXISTS `ob_stock` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '仓库编号',

`g_id` int(10) NOT NULL COMMENT '货物编号',

`war_id` int(10) NOT NULL COMMENT '仓库编号',

`st_number` int(11) NOT NULL COMMENT '库存数量',

`max` int(11) NOT NULL COMMENT '库存最大值',

`min` time NOT NULL COMMENT '库存最小值',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='友情链接表' AUTO_INCREMENT=1 ;

-- --------------------------------------------------------

--

-- 表的结构 `ob_warehouse`

--

CREATE TABLE IF NOT EXISTS `ob_warehouse` (

`war_id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '仓库编号',

`name` char(50) NOT NULL DEFAULT '' COMMENT '仓库名称',

`address` char(20) NOT NULL COMMENT '仓库地址',

`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '数据状态',

`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

`update_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

PRIMARY KEY (`war_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='仓库管理表' AUTO_INCREMENT=1 ;

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;

/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;

/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

一键复制

编辑

Web IDE

原始数据

按行查看

历史

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值