作者 王晓刚

部署到服务器

正在显示 40 个修改的文件 包含 1648 行增加2579 行删除
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/25
* Time: 11:49
*/
namespace app\admin\controller;
use cmf\controller\AdminBaseController;
use think\Db;
use think\Validate;
class CollocationController extends AdminBaseController
{
public function index(){
$where=[];
$param = $this->request->param();
$keyword = empty($param['keyword']) ? '' : $param['keyword'];
if (!empty($keyword)) {
$where['product_name|application|insurer'] = ['like', "%$keyword%"];
}
$data=Db::name('collocation')
->where('delete_time',0)
->where($where)
->order('create_time desc')
->paginate(10);
$list = $data->items();
foreach($list as $key => $l){
$subjoin_insurance = Db::name('subjoin_insurance')->where(array('delete_time'=>0,'collocation_id',$list['id']))->select()->toArray();
$list[$key]['subjoin_insurance'] = $subjoin_insurance;
}
$data->appends($param);
$this->assign([
'data'=>$list,
'page'=>$data->render(),
'keyword'=>$keyword,
]);
return $this->fetch();
}
//编辑
public function edit(){
$id=$this->request->param('id', 0, 'intval');
if($this->request->isPost()){
$param=$this->request->param();
$validate = new Validate([
'insurance_company_id' => 'require',
'product_name' => 'require',
'insurance_type_id' => 'require',
'insurance_price' => 'require',
'pay_method_id' => 'require',
'pay_method_price' => 'require',
'guarantee_deadline' => 'require',
'insurance_num' => 'require',
'application' => 'require',
'insurer' => 'require',
'relation' => 'require',
'insurer_birthday' => 'require',
'insurer_time' => 'require',
'take_time' => 'require',
'insure_time' => 'require',
'remit' => 'require',
]);
$validate->message([
'insurance_company_id' => '请选择保险公司!',
'product_name' => '产品名称不能为空!',
'insurance_type_id' => '请选择保险类型!',
'insurance_price' => '保险金额不能为空!',
'pay_method_id' => '请选择缴费方式!',
'pay_method_price' => '期缴保费不能为空!',
'guarantee_deadline' => '请选择保障期限!',
'insurance_num' => '保险单号不能为空!',
'application' => '投保人不能为空!',
'insurer' => '保险人不能为空!',
'relation' => '请选择与保险人关系!',
'insurer_birthday' => '保险人生日不能为空!',
'insurer_time' => '投保日期不能为空!',
'take_time' => '合同生效日期不能为空!',
'insure_time' => '保险时间不能为空!',
'remit' => '请选择保单豁免!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
$param['update_time']=time();
Db::name('insurance_company')
->where('id',$id)
->update($param);
$this->success('更新成功!');
}else{
$data=Db::name('collocation')
->where('id',$id)
->find();
$subjoin_insurance = Db::name('subjoin_insurance')->where(array('delete_time'=>0,'collocation_id',$data['id']))->find();
$data['subjoin_insurance'] = $subjoin_insurance;
$this->assign([
'data'=>$data,
]);
return $this->fetch();
}
}
//删除
public function delete(){
$param = $this->request->param();
if (isset($param['id'])) {
$id = $this->request->param('id', 0, 'intval');
$resultPortal = Db::name('collocation')
->where(['id' => $id])
->update(['delete_time' => time()]);
if($resultPortal){
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
if (isset($param['ids'])) {
$ids = $this->request->param('ids/a');
$result = Db::name('collocation')
->where(['id' => ['in', $ids]])
->update(['delete_time' => time()]);
if ($result) {
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
}
}
\ No newline at end of file
... ...
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/24
* Time: 19:35
*/
namespace app\admin\controller;
use cmf\controller\AdminBaseController;
use think\Db;
use think\Validate;
class InsuranceCompanyController extends AdminBaseController
{
public function index(){
$where=[];
$param = $this->request->param();
$keyword = empty($param['keyword']) ? '' : $param['keyword'];
if (!empty($keyword)) {
$where['insurance_company_name'] = ['like', "%$keyword%"];
}
$data=Db::name('insurance_company')
->where('delete_time',0)
->where($where)
->order('create_time desc')
->paginate(10);
$data->appends($param);
$this->assign([
'data'=>$data,
'page'=>$data->render(),
'keyword'=>$keyword,
]);
return $this->fetch();
}
//编辑
public function edit(){
$id=$this->request->param('id', 0, 'intval');
if($this->request->isPost()){
$param=$this->request->param();
$validate = new Validate([
'insurance_company_name' => 'require',
'thumbnail' => 'require',
]);
$validate->message([
'insurance_company_name' => '保险公司不能为空!',
'thumbnail' => '请上传缩略图!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
$param['update_time']=time();
Db::name('insurance_company')
->where('id',$id)
->update($param);
$this->success('更新成功!');
}else{
$data = Db::name('insurance_company')
->where('id', $id)
->find();
$this->assign([
'data'=>$data,
]);
return $this->fetch();
}
}
//添加
public function add(){
if($this->request->isPost()){
$param=$this->request->param();
$param['create_time']=time();
$param['update_time']=time();
$validate = new Validate([
'insurance_company_name' => 'require',
'thumbnail' => 'require',
]);
$validate->message([
'insurance_company_name' => '保险公司不能为空!',
'thumbnail' => '请上传缩略图!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
Db::name('insurance_company')
->insertGetId($param);
$this->success('添加成功!');
}else{
return $this->fetch();
}
}
//删除
public function delete(){
$param = $this->request->param();
if (isset($param['id'])) {
$id = $this->request->param('id', 0, 'intval');
$resultPortal = Db::name('insurance_company')
->where(['id' => $id])
->update(['delete_time' => time()]);
if($resultPortal){
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
if (isset($param['ids'])) {
$ids = $this->request->param('ids/a');
$result = Db::name('insurance_company')
->where(['id' => ['in', $ids]])
->update(['delete_time' => time()]);
if ($result) {
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
}
}
\ No newline at end of file
... ...
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/25
* Time: 8:46
*/
namespace app\admin\controller;
use cmf\controller\AdminBaseController;
use think\Db;
use think\Validate;
class InsuranceTypeController extends AdminBaseController
{
public function index(){
$where=[];
$param = $this->request->param();
$keyword = empty($param['keyword']) ? '' : $param['keyword'];
if (!empty($keyword)) {
$where['insurance_type_name'] = ['like', "%$keyword%"];
}
$data=Db::name('insurance_type')
->where('delete_time',0)
->where($where)
->order('list_order asc,create_time desc')
->paginate(10);
$data->appends($param);
$this->assign([
'data'=>$data,
'page'=>$data->render(),
'keyword'=>$keyword,
]);
return $this->fetch();
}
//编辑
public function edit(){
$id=$this->request->param('id', 0, 'intval');
if($this->request->isPost()){
$param=$this->request->param();
$validate = new Validate([
'insurance_type_name' => 'require',
]);
$validate->message([
'insurance_type_name' => '保险类型不能为空!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
$param['update_time']=time();
Db::name('insurance_type')
->where('id',$id)
->update($param);
$this->success('更新成功!');
}else{
$data = Db::name('insurance_type')
->where('id', $id)
->find();
$this->assign([
'data'=>$data,
]);
return $this->fetch();
}
}
//添加
public function add(){
if($this->request->isPost()){
$param=$this->request->param();
$param['create_time']=time();
$param['update_time']=time();
$validate = new Validate([
'insurance_type_name' => 'require',
]);
$validate->message([
'insurance_type_name' => '保险类型不能为空!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
Db::name('insurance_type')
->insertGetId($param);
$this->success('添加成功!');
}else{
return $this->fetch();
}
}
//删除
public function delete(){
$param = $this->request->param();
if (isset($param['id'])) {
$id = $this->request->param('id', 0, 'intval');
$resultPortal = Db::name('insurance_type')
->where(['id' => $id])
->update(['delete_time' => time()]);
if($resultPortal){
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
if (isset($param['ids'])) {
$ids = $this->request->param('ids/a');
$result = Db::name('insurance_type')
->where(['id' => ['in', $ids]])
->update(['delete_time' => time()]);
if ($result) {
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
}
//排序
public function listOrder(){
$ids=$this->request->param('list_orders/a');
if (!empty($ids)) {
foreach ($ids as $key => $r) {
$data['list_order'] = $r;
Db::name('insurance_type')->where('id',$key)->update($data);
}
}
$this->success('排序成功!','');
}
}
\ No newline at end of file
... ...
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/25
* Time: 8:46
*/
namespace app\admin\controller;
use cmf\controller\AdminBaseController;
use think\Db;
use think\Validate;
class PayMethodController extends AdminBaseController
{
public function index(){
$where=[];
$param = $this->request->param();
$keyword = empty($param['keyword']) ? '' : $param['keyword'];
if (!empty($keyword)) {
$where['pay_method_name'] = ['like', "%$keyword%"];
}
$data=Db::name('pay_method')
->where('delete_time',0)
->where($where)
->order('create_time desc')
->paginate(10);
$data->appends($param);
$this->assign([
'data'=>$data,
'page'=>$data->render(),
'keyword'=>$keyword,
]);
return $this->fetch();
}
//编辑
public function edit(){
$id=$this->request->param('id', 0, 'intval');
if($this->request->isPost()){
$param=$this->request->param();
$validate = new Validate([
'pay_method_name' => 'require',
]);
$validate->message([
'pay_method_name' => '缴费方式不能为空!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
$param['update_time']=time();
Db::name('pay_method')
->where('id',$id)
->update($param);
$this->success('更新成功!');
}else{
$data = Db::name('pay_method')
->where('id', $id)
->find();
$this->assign([
'data'=>$data,
]);
return $this->fetch();
}
}
//添加
public function add(){
if($this->request->isPost()){
$param=$this->request->param();
$param['create_time']=time();
$param['update_time']=time();
$validate = new Validate([
'pay_method_name' => 'require',
]);
$validate->message([
'pay_method_name' => '缴费方式不能为空!',
]);
if (!$validate->check($param)) {
$this->error($validate->getError());
}
Db::name('pay_method')
->insertGetId($param);
$this->success('添加成功!');
}else{
return $this->fetch();
}
}
//删除
public function delete(){
$param = $this->request->param();
if (isset($param['id'])) {
$id = $this->request->param('id', 0, 'intval');
$resultPortal = Db::name('pay_method')
->where(['id' => $id])
->update(['delete_time' => time()]);
if($resultPortal){
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
if (isset($param['ids'])) {
$ids = $this->request->param('ids/a');
$result = Db::name('pay_method')
->where(['id' => ['in', $ids]])
->update(['delete_time' => time()]);
if ($result) {
$this->success("删除成功!", '');
}else{
$this->error("删除失败!", '');
}
}
}
}
\ No newline at end of file
... ...
... ... @@ -59,7 +59,7 @@ $configs = [
// | 模块设置
// +----------------------------------------------------------------------
// 默认模块名
'default_module' => 'portal',
'default_module' => 'index',
// 禁止访问模块
'deny_module_list' => ['common'],
// 默认控制器名
... ...
... ... @@ -15,8 +15,8 @@ return [
/**
* 账号基本信息,请从微信公众平台/开放平台获取
*/
'app_id' => 'wxb4238fbc5c39db5d', // AppID
'secret' => '9d95998ab1a23374c7235a30b53f3a3c', // AppSecret
'app_id' => 'wx9c9b1792b4eb40a1', // AppID
'secret' => 'de15055ef7909201e2ca45ed33697f52', // AppSecret
'token' => 'bronet', // Token
'aes_key' => 'qblu4O3peCTWjLLEqKqLjQhJNNeCTi2se2EPeVARsbk', // EncodingAESKey,安全模式下请一定要填写!!!
/**
... ... @@ -46,8 +46,8 @@ return [
* 微信支付
*/
'payment' => [
'merchant_id' => '1509104971',
'key' => 'ebfe7fba8f7a0fba3e19efcc547b956d',
'merchant_id' => '1520128801',
'key' => 'zYlhowF3PEFhWoFIP3YEdWSHpLBLlJcS',
'cert_path' => 'wechat/cert/apiclient_cert.pem', // XXX: 绝对路径!!!!
'key_path' => 'wechat/cert/apiclient_key.pem', // XXX: 绝对路径!!!!
// 'device_info' => '013467007045764',
... ...
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/24
* Time: 18:51
*/
namespace app\index\controller;
use cmf\controller\WeChatBaseController;
use think\Db;
class IndexController extends WeChatBaseController
{
//授权
function _initialize()
{
// //判断用户是否微信浏览器打开
// $this->isWechat();
// //微信授权
// parent::_initialize();
// $this->checkWeChatUserLogin();
// //阻止拉黑用户
// $this->ban();
}
public function index(){
$this->success('咳咳','');
}
}
\ No newline at end of file
... ...
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/12/25
* Time: 15:34
*/
namespace app\index\controller;
use cmf\controller\WeChatBaseController;
use think\Db;
class RegisterMobileController extends WeChatBaseController
{
//授权
function _initialize()
{
//判断用户是否微信浏览器打开
$this->isWechat();
//微信授权
parent::_initialize();
$this->checkWeChatUserLogin();
//阻止拉黑用户
$this->ban();
}
/**
* @title 注册手机号页面
* @author XiangGang Wang
* @time 2018年12月25日15:38:58
*/
public function index(){
$is_select = $this->request->param('is_select', 0, 'intval');;
$this->assign(
array(
'title'=>'注册',
'is_select'=>$is_select,
)
);
return $this->fetch();
}
/**
* @title 获取验证码
* @author XiangGang Wang
* @time 2018年12月25日15:36:20
*/
public function getCode(){
$content=$this->generate_code();
$user_id = cmf_get_current_user_id();
//获取手机号
$mobile = $this->request->post('phone');
if(empty($mobile)){
$arr['code'] = 40001;
$arr['msg'] = "缺少参数phone!";
return json_encode($arr);
}
require_once CMF_PATH . 'common.php';
$data = array(
'content' => "【橙象保险】您的验证码是:".$content.",请于5分钟内使用,如非本人操作,可忽略此消息。",//短信内容
'mobile' => $mobile,//手机号码
'productid' => '887361',//产品id
'xh' => ''//小号
);
$result = send_sms($data);
if(substr($result,0,strpos($result,',')) == "1"){
//保存到数据库
$isin=Db::name('code')->where(array('phone'=>$mobile,'user_id'=>$user_id))->find();
if($isin){
$data1['code']=$content;
$data1['update_time']=time();
$data1['end_time']=time()+300;//过期时间
Db::name('code')->where('user_id',$user_id)->update($data1);
}else{
$data1['user_id']=$user_id;
$data1['phone']=$mobile;
$data1['code']=$content;
$data1['create_time']=time();
$data1['end_time']=time()+300;//过期时间
Db::name('code')->insert($data1);
}
$arr['code'] = 20000;
$arr['msg'] = "验证码获取成功!";
return json_encode($arr);
}else{
$arr['code'] = 40000;
$arr['msg'] = '短信接口出错';
$arr['data'] = $result;
return $arr;
}
}
/**
* @title 注册手机号
* @author XiangGang Wang
* @time 2018年12月25日15:35:52
*/
public function register_mobile(){
$user_id = cmf_get_current_user_id();
$name= $this->request->post('name');
$mobile = $this->request->post('phone');
$code = $this->request->post('code');
$consent = $this->request->post('consent');
if(empty($name) || empty($mobile) || empty($code)){
$arr['code'] = 40001;
$arr['msg'] = "缺少必要参数!";
return json_encode($arr);
}
if(empty($consent)){
$arr['code'] = 40004;
$arr['msg'] = "请同意协议!";
return json_encode($arr);
}
$codeData = Db::name('code')->where(array('phone'=>$mobile,'user_id'=>$user_id))->find();
//判断验证码是否正确
if($codeData['code'] != $code){
$arr['code'] = 40002;
$arr['msg'] = "验证码错误!";
return json_encode($arr);
}
//判断验证码是否过期
if($codeData['end_time']<time()){
$arr['code'] = 40003;
$arr['msg'] = "验证码已过期!";
return json_encode($arr);
}
Db::name('user')->where('id',$user_id)->update(array('mobile'=>$mobile,'name'=>$name));
$arr['code'] = 20000;
$arr['msg'] = "注册成功!";
return json_encode($arr);
}
/**
* 生成6位随机数
* @param string
* @return boolean
*/
public function generate_code($length = 6) {
$min = pow(10 , ($length - 1));
$max = pow(10, $length) - 1;
return rand($min, $max);
}
}
\ No newline at end of file
... ...
<?php
// +----------------------------------------------------------------------
// | bronet [ 以客户为中心 以奋斗者为本 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2017 http://www.bronet.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老猫 <bronet@126.com>
// +----------------------------------------------------------------------
function sp_testwrite($d)
{
$tfile = "_test.txt";
$fp = @fopen($d . "/" . $tfile, "w");
if (!$fp) {
return false;
}
fclose($fp);
$rs = @unlink($d . "/" . $tfile);
if ($rs) {
return true;
}
return false;
}
function sp_dir_create($path, $mode = 0777)
{
if (is_dir($path))
return true;
$ftp_enable = 0;
$path = sp_dir_path($path);
$temp = explode('/', $path);
$cur_dir = '';
$max = count($temp) - 1;
for ($i = 0; $i < $max; $i++) {
$cur_dir .= $temp[$i] . '/';
if (@is_dir($cur_dir))
continue;
@mkdir($cur_dir, 0777, true);
@chmod($cur_dir, 0777);
}
return is_dir($path);
}
function sp_dir_path($path)
{
$path = str_replace('\\', '/', $path);
if (substr($path, -1) != '/')
$path = $path . '/';
return $path;
}
function sp_execute_sql($db, $sql)
{
$sql = trim($sql);
preg_match('/CREATE TABLE .+ `([^ ]*)`/', $sql, $matches);
if ($matches) {
$table_name = $matches[1];
$msg = "创建数据表{$table_name}";
try {
$db->execute($sql);
return [
'error' => 0,
'message' => $msg . ' 成功!'
];
} catch (\Exception $e) {
return [
'error' => 1,
'message' => $msg . ' 失败!',
'exception' => $e->getTraceAsString()
];
}
} else {
try {
$db->execute($sql);
return [
'error' => 0,
'message' => 'SQL执行成功!'
];
} catch (\Exception $e) {
return [
'error' => 1,
'message' => 'SQL执行失败!',
'exception' => $e->getTraceAsString()
];
}
}
}
/**
* 显示提示信息
* @param string $msg 提示信息
*/
function sp_show_msg($msg, $class = '')
{
echo "<script type=\"text/javascript\">showmsg(\"{$msg}\", \"{$class}\")</script>";
flush();
ob_flush();
}
function sp_update_site_configs($db, $table_prefix)
{
$sitename = I("post.sitename");
$email = I("post.manager_email");
$siteurl = I("post.siteurl");
$seo_keywords = I("post.sitekeywords");
$seo_description = I("post.siteinfo");
$site_options = <<<helllo
{
"site_name":"$sitename",
"site_host":"$siteurl",
"site_root":"",
"site_icp":"",
"site_admin_email":"$email",
"site_tongji":"",
"site_copyright":"",
"site_seo_title":"$sitename",
"site_seo_keywords":"$seo_keywords",
"site_seo_description":"$seo_description"
}
helllo;
$sql = "INSERT INTO `{$table_prefix}options` (option_value,option_name) VALUES ('$site_options','site_options')";
$db->execute($sql);
sp_show_msg("网站信息配置成功!");
}
function sp_create_admin_account($db, $table_prefix, $authcode)
{
$username = I("post.manager");
$password = sp_password(I("post.manager_pwd"), $authcode);
$email = I("post.manager_email");
$create_date = date("Y-m-d h:i:s");
$ip = get_client_ip(0, true);
$sql = <<<hello
INSERT INTO `{$table_prefix}users`
(id,user_login,user_pass,user_nicename,user_email,user_url,create_time,user_activation_key,user_status,last_login_ip,last_login_time) VALUES
('1', '{$username}', '{$password}', 'admin', '{$email}', '', '{$create_date}', '', '1', '{$ip}','{$create_date}');;
hello;
$db->execute($sql);
sp_show_msg("管理员账号创建成功!");
}
/**
* 写入配置文件
* @param array $config 配置信息
*/
function sp_create_config($config, $authcode)
{
if (is_array($config)) {
//读取配置内容
$conf = file_get_contents(MODULE_PATH . 'Data/config.php');
//替换配置项
foreach ($config as $key => $value) {
$conf = str_replace("#{$key}#", $value, $conf);
}
$conf = str_replace('#AUTHCODE#', $authcode, $conf);
$conf = str_replace('#COOKIE_PREFIX#', sp_random_string(6) . "_", $conf);
//写入应用配置文件
if (file_put_contents('data/conf/db.php', $conf)) {
sp_show_msg('配置文件写入成功');
} else {
sp_show_msg('配置文件写入失败!', 'error');
}
return '';
}
}
function sp_create_db_config($config)
{
if (is_array($config)) {
//读取配置内容
$conf = file_get_contents(APP_PATH . 'install/data/config.php');
//替换配置项
foreach ($config as $key => $value) {
$conf = str_replace("#{$key}#", $value, $conf);
}
try {
$confDir = CMF_ROOT . 'data/conf/';
if (!file_exists($confDir)) {
mkdir($confDir, 0777, true);
}
file_put_contents(CMF_ROOT . 'data/conf/database.php', $conf);
} catch (\Exception $e) {
return false;
}
return true;
}
}
<?php
// +----------------------------------------------------------------------
// | bronet [ 以客户为中心 以奋斗者为本 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2017 http://www.bronet.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老猫 <bronet@126.com>
// +----------------------------------------------------------------------
return [];
<?php
// +----------------------------------------------------------------------
// | bronet [ 以客户为中心 以奋斗者为本 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2017 http://www.bronet.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老猫 <bronet@126.com>
// +----------------------------------------------------------------------
namespace app\install\controller;
use app\admin\model\ThemeModel;
use think\Controller;
use think\Db;
class IndexController extends Controller
{
public function _initialize()
{
if (cmf_is_installed()) {
$this->error('网站已经安装', cmf_get_root() . '/');
}
}
// 安装首页
public function index()
{
return $this->fetch(":index");
}
public function step2()
{
// if (file_exists_case('data/conf/config.php')) {
// @unlink('data/conf/config.php');
// }
$data = [];
$data['phpversion'] = @phpversion();
$data['os'] = PHP_OS;
$tmp = function_exists('gd_info') ? gd_info() : [];
// $server = $_SERVER["SERVER_SOFTWARE"];
// $host = $this->request->host();
// $name = $_SERVER["SERVER_NAME"];
// $max_execution_time = ini_get('max_execution_time');
// $allow_reference = (ini_get('allow_call_time_pass_reference') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
// $allow_url_fopen = (ini_get('allow_url_fopen') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
// $safe_mode = (ini_get('safe_mode') ? '<font color=red>[×]On</font>' : '<font color=green>[√]Off</font>');
$err = 0;
if (empty($tmp['GD Version'])) {
$gd = '<font color=red>[×]Off</font>';
$err++;
} else {
$gd = '<font color=green>[√]On</font> ' . $tmp['GD Version'];
}
if (class_exists('pdo')) {
$data['pdo'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['pdo'] = '<i class="fa fa-remove error"></i> 未开启';
$err++;
}
if (extension_loaded('pdo_mysql')) {
$data['pdo_mysql'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['pdo_mysql'] = '<i class="fa fa-remove error"></i> 未开启';
$err++;
}
if (extension_loaded('curl')) {
$data['curl'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['curl'] = '<i class="fa fa-remove error"></i> 未开启';
$err++;
}
if (extension_loaded('gd')) {
$data['gd'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['gd'] = '<i class="fa fa-remove error"></i> 未开启';
if (function_exists('imagettftext')) {
$data['gd'] .= '<br><i class="fa fa-remove error"></i> FreeType Support未开启';
}
$err++;
}
if (extension_loaded('mbstring')) {
$data['mbstring'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['mbstring'] = '<i class="fa fa-remove error"></i> 未开启';
if (function_exists('imagettftext')) {
$data['mbstring'] .= '<br><i class="fa fa-remove error"></i> FreeType Support未开启';
}
$err++;
}
if (extension_loaded('fileinfo')) {
$data['fileinfo'] = '<i class="fa fa-check correct"></i> 已开启';
} else {
$data['fileinfo'] = '<i class="fa fa-remove error"></i> 未开启';
$err++;
}
if (ini_get('file_uploads')) {
$data['upload_size'] = '<i class="fa fa-check correct"></i> ' . ini_get('upload_max_filesize');
} else {
$data['upload_size'] = '<i class="fa fa-remove error"></i> 禁止上传';
}
if (function_exists('session_start')) {
$data['session'] = '<i class="fa fa-check correct"></i> 支持';
} else {
$data['session'] = '<i class="fa fa-remove error"></i> 不支持';
$err++;
}
if (version_compare(phpversion(), '5.6.0', '>=') && version_compare(phpversion(), '7.0.0', '<') && ini_get('always_populate_raw_post_data') != -1) {
$data['always_populate_raw_post_data'] = '<i class="fa fa-remove error"></i> 未关闭';
$data['show_always_populate_raw_post_data_tip'] = true;
$err++;
} else {
$data['always_populate_raw_post_data'] = '<i class="fa fa-check correct"></i> 已关闭';
}
$folders = [
realpath(CMF_ROOT . 'data') . DS,
realpath('./upload') . DS,
];
$newFolders = [];
foreach ($folders as $dir) {
$testDir = $dir;
sp_dir_create($testDir);
if (sp_testwrite($testDir)) {
$newFolders[$dir]['w'] = true;
} else {
$newFolders[$dir]['w'] = false;
$err++;
}
if (is_readable($testDir)) {
$newFolders[$dir]['r'] = true;
} else {
$newFolders[$dir]['r'] = false;
$err++;
}
}
$data['folders'] = $newFolders;
$this->assign($data);
return $this->fetch(":step2");
}
public function step3()
{
return $this->fetch(":step3");
}
public function step4()
{
session(null);
if ($this->request->isPost()) {
//创建数据库
$dbConfig = [];
$dbConfig['type'] = "mysql";
$dbConfig['hostname'] = $this->request->param('dbhost');
$dbConfig['username'] = $this->request->param('dbuser');
$dbConfig['password'] = $this->request->param('dbpw');
$dbConfig['hostport'] = $this->request->param('dbport');
$dbConfig['charset'] = $this->request->param('dbcharset', 'utf8mb4');
$db = Db::connect($dbConfig);
$dbName = $this->request->param('dbname');
$sql = "CREATE DATABASE IF NOT EXISTS `{$dbName}` DEFAULT CHARACTER SET " . $dbConfig['charset'];
$db->execute($sql) || $this->error($db->getError());
$dbConfig['database'] = $dbName;
$dbConfig['prefix'] = $this->request->param('dbprefix', '', 'trim');
session('install.db_config', $dbConfig);
$sql = cmf_split_sql(APP_PATH . 'install/data/thinkcmf.sql', $dbConfig['prefix'], $dbConfig['charset']);
session('install.sql', $sql);
$this->assign('sql_count', count($sql));
session('install.error', 0);
$siteName = $this->request->param('sitename');
$seoKeywords = $this->request->param('sitekeywords');
$siteInfo = $this->request->param('siteinfo');
session('install.site_info', [
'site_name' => $siteName,
'site_seo_title' => $siteName,
'site_seo_keywords' => $seoKeywords,
'site_seo_description' => $siteInfo
]);
$userLogin = $this->request->param('manager');
$userPass = $this->request->param('manager_pwd');
$userEmail = $this->request->param('manager_email');
session('install.admin_info', [
'user_login' => $userLogin,
'user_pass' => $userPass,
'user_email' => $userEmail
]);
return $this->fetch(":step4");
} else {
exit;
}
}
public function install()
{
$dbConfig = session('install.db_config');
$sql = session('install.sql');
if (empty($dbConfig) || empty($sql)) {
$this->error("非法安装!");
}
$sqlIndex = $this->request->param('sql_index', 0, 'intval');
$db = Db::connect($dbConfig);
if ($sqlIndex >= count($sql)) {
$installError = session('install.error');
$this->success("安装完成!", '', ['done' => 1, 'error' => $installError]);
}
$sqlToExec = $sql[$sqlIndex] . ';';
$result = sp_execute_sql($db, $sqlToExec);
if (!empty($result['error'])) {
$installError = session('install.error');
$installError = empty($installError) ? 0 : $installError;
session('install.error', $installError + 1);
$this->error($result['message'], '', [
'sql' => $sqlToExec,
'exception' => $result['exception']
]);
} else {
$this->success($result['message'], '', [
'sql' => $sqlToExec
]);
}
}
public function setDbConfig()
{
$dbConfig = session('install.db_config');
$dbConfig['authcode'] = cmf_random_string(18);
$result = sp_create_db_config($dbConfig);
if ($result) {
$this->success("数据配置文件写入成功!");
} else {
$this->error("数据配置文件写入失败!");
}
}
public function setSite()
{
$dbConfig = session('install.db_config');
if (empty($dbConfig)) {
$this->error("非法安装!");
}
$siteInfo = session('install.site_info');
$admin = session('install.admin_info');
$admin['id'] = 1;
$admin['user_pass'] = cmf_password($admin['user_pass']);
$admin['user_type'] = 1;
$admin['create_time'] = time();
$admin['user_status'] = 1;
$admin['user_nickname'] = $admin['user_login'];
try {
cmf_set_option('site_info', $siteInfo);
Db::name('user')->insert($admin);
} catch (\Exception $e) {
$this->error("网站创建失败!");
}
$this->success("网站创建完成!");
}
public function installTheme()
{
$themeModel = new ThemeModel();
$result = $themeModel->installTheme(config('cmf_default_theme'));
if ($result === false) {
$this->error('模板不存在!');
}
session("install.step", 4);
$this->success("模板安装成功");
}
public function step5()
{
if (session("install.step") == 4) {
@touch(CMF_ROOT . 'data/install.lock');
return $this->fetch(":step5");
} else {
$this->error("非法安装!");
}
}
public function testDbPwd()
{
if ($this->request->isPost()) {
$dbConfig = $this->request->param();
$dbConfig['type'] = "mysql";
try {
Db::connect($dbConfig)->query("SELECT VERSION();");
} catch (\Exception $e) {
die("");
}
exit("1");
} else {
exit("need post!");
}
}
}
<?php
/**
* 配置文件
*/
return [
// 数据库类型
'type' => 'mysql',
// 服务器地址
'hostname' => '#hostname#',
// 数据库名
'database' => '#database#',
// 用户名
'username' => '#username#',
// 密码
'password' => '#password#',
// 端口
'hostport' => '#hostport#',
// 数据库编码默认采用utf8
'charset' => '#charset#',
// 数据库表前缀
'prefix' => '#prefix#',
"authcode" => '#authcode#',
//#COOKIE_PREFIX#
];
--
-- 表的结构 `cmf_admin_menu`
--
CREATE TABLE IF NOT EXISTS `cmf_admin_menu` (
`id` int(10) unsigned NOT NULL,
`parent_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父菜单id',
`type` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '菜单类型;1:有界面可访问菜单,2:无界面可访问菜单,0:只作为菜单',
`status` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '状态;1:显示,0:不显示',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`app` varchar(15) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '应用名',
`controller` varchar(30) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '控制器名',
`action` varchar(30) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '操作名称',
`param` varchar(50) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '额外参数',
`name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '菜单名称',
`icon` varchar(20) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '菜单图标',
`remark` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '备注'
) ENGINE=InnoDB AUTO_INCREMENT=154 DEFAULT CHARSET=utf8mb4 COMMENT='后台菜单表';
--
-- 转存表中的数据 `cmf_admin_menu`
--
INSERT INTO `cmf_admin_menu` VALUES ('1', '0', '0', '1', '20', 'admin', 'Plugin', 'default', '', '插件管理', 'cloud', '插件管理'), ('2', '1', '1', '1', '10000', 'admin', 'Hook', 'index', '', '钩子管理', '', '钩子管理'), ('3', '2', '1', '0', '10000', 'admin', 'Hook', 'plugins', '', '钩子插件管理', '', '钩子插件管理'), ('4', '2', '2', '0', '10000', 'admin', 'Hook', 'pluginListOrder', '', '钩子插件排序', '', '钩子插件排序'), ('5', '2', '1', '0', '10000', 'admin', 'Hook', 'sync', '', '同步钩子', '', '同步钩子'), ('6', '0', '0', '1', '0', 'admin', 'Setting', 'default', '', '设置', 'cogs', '系统设置入口'), ('7', '6', '1', '1', '50', 'admin', 'Link', 'index', '', '友情链接', '', '友情链接管理'), ('8', '7', '1', '0', '10000', 'admin', 'Link', 'add', '', '添加友情链接', '', '添加友情链接'), ('9', '7', '2', '0', '10000', 'admin', 'Link', 'addPost', '', '添加友情链接提交保存', '', '添加友情链接提交保存'), ('10', '7', '1', '0', '10000', 'admin', 'Link', 'edit', '', '编辑友情链接', '', '编辑友情链接'), ('11', '7', '2', '0', '10000', 'admin', 'Link', 'editPost', '', '编辑友情链接提交保存', '', '编辑友情链接提交保存'), ('12', '7', '2', '0', '10000', 'admin', 'Link', 'delete', '', '删除友情链接', '', '删除友情链接'), ('13', '7', '2', '0', '10000', 'admin', 'Link', 'listOrder', '', '友情链接排序', '', '友情链接排序'), ('14', '7', '2', '0', '10000', 'admin', 'Link', 'toggle', '', '友情链接显示隐藏', '', '友情链接显示隐藏'), ('15', '6', '1', '1', '10', 'admin', 'Mailer', 'index', '', '邮箱配置', '', '邮箱配置'), ('16', '15', '2', '0', '10000', 'admin', 'Mailer', 'indexPost', '', '邮箱配置提交保存', '', '邮箱配置提交保存'), ('17', '15', '1', '0', '10000', 'admin', 'Mailer', 'template', '', '邮件模板', '', '邮件模板'), ('18', '15', '2', '0', '10000', 'admin', 'Mailer', 'templatePost', '', '邮件模板提交', '', '邮件模板提交'), ('19', '15', '1', '0', '10000', 'admin', 'Mailer', 'test', '', '邮件发送测试', '', '邮件发送测试'), ('20', '6', '1', '0', '10000', 'admin', 'Menu', 'index', '', '后台菜单', '', '后台菜单管理'), ('21', '20', '1', '0', '10000', 'admin', 'Menu', 'lists', '', '所有菜单', '', '后台所有菜单列表'), ('22', '20', '1', '0', '10000', 'admin', 'Menu', 'add', '', '后台菜单添加', '', '后台菜单添加'), ('23', '20', '2', '0', '10000', 'admin', 'Menu', 'addPost', '', '后台菜单添加提交保存', '', '后台菜单添加提交保存'), ('24', '20', '1', '0', '10000', 'admin', 'Menu', 'edit', '', '后台菜单编辑', '', '后台菜单编辑'), ('25', '20', '2', '0', '10000', 'admin', 'Menu', 'editPost', '', '后台菜单编辑提交保存', '', '后台菜单编辑提交保存'), ('26', '20', '2', '0', '10000', 'admin', 'Menu', 'delete', '', '后台菜单删除', '', '后台菜单删除'), ('27', '20', '2', '0', '10000', 'admin', 'Menu', 'listOrder', '', '后台菜单排序', '', '后台菜单排序'), ('28', '20', '1', '0', '10000', 'admin', 'Menu', 'getActions', '', '导入新后台菜单', '', '导入新后台菜单'), ('29', '6', '1', '1', '30', 'admin', 'Nav', 'index', '', '导航管理', '', '导航管理'), ('30', '29', '1', '0', '10000', 'admin', 'Nav', 'add', '', '添加导航', '', '添加导航'), ('31', '29', '2', '0', '10000', 'admin', 'Nav', 'addPost', '', '添加导航提交保存', '', '添加导航提交保存'), ('32', '29', '1', '0', '10000', 'admin', 'Nav', 'edit', '', '编辑导航', '', '编辑导航'), ('33', '29', '2', '0', '10000', 'admin', 'Nav', 'editPost', '', '编辑导航提交保存', '', '编辑导航提交保存'), ('34', '29', '2', '0', '10000', 'admin', 'Nav', 'delete', '', '删除导航', '', '删除导航'), ('35', '29', '1', '0', '10000', 'admin', 'NavMenu', 'index', '', '导航菜单', '', '导航菜单'), ('36', '35', '1', '0', '10000', 'admin', 'NavMenu', 'add', '', '添加导航菜单', '', '添加导航菜单'), ('37', '35', '2', '0', '10000', 'admin', 'NavMenu', 'addPost', '', '添加导航菜单提交保存', '', '添加导航菜单提交保存'), ('38', '35', '1', '0', '10000', 'admin', 'NavMenu', 'edit', '', '编辑导航菜单', '', '编辑导航菜单'), ('39', '35', '2', '0', '10000', 'admin', 'NavMenu', 'editPost', '', '编辑导航菜单提交保存', '', '编辑导航菜单提交保存'), ('40', '35', '2', '0', '10000', 'admin', 'NavMenu', 'delete', '', '删除导航菜单', '', '删除导航菜单'), ('41', '35', '2', '0', '10000', 'admin', 'NavMenu', 'listOrder', '', '导航菜单排序', '', '导航菜单排序'), ('42', '1', '1', '1', '10000', 'admin', 'Plugin', 'index', '', '插件列表', '', '插件列表'), ('43', '42', '2', '0', '10000', 'admin', 'Plugin', 'toggle', '', '插件启用禁用', '', '插件启用禁用'), ('44', '42', '1', '0', '10000', 'admin', 'Plugin', 'setting', '', '插件设置', '', '插件设置'), ('45', '42', '2', '0', '10000', 'admin', 'Plugin', 'settingPost', '', '插件设置提交', '', '插件设置提交'), ('46', '42', '2', '0', '10000', 'admin', 'Plugin', 'install', '', '插件安装', '', '插件安装'), ('47', '42', '2', '0', '10000', 'admin', 'Plugin', 'update', '', '插件更新', '', '插件更新'), ('48', '42', '2', '0', '10000', 'admin', 'Plugin', 'uninstall', '', '卸载插件', '', '卸载插件'), ('49', '109', '0', '1', '10000', 'admin', 'User', 'default', '', '管理组', '', '管理组'), ('50', '49', '1', '1', '10000', 'admin', 'Rbac', 'index', '', '角色管理', '', '角色管理'), ('51', '50', '1', '0', '10000', 'admin', 'Rbac', 'roleAdd', '', '添加角色', '', '添加角色'), ('52', '50', '2', '0', '10000', 'admin', 'Rbac', 'roleAddPost', '', '添加角色提交', '', '添加角色提交'), ('53', '50', '1', '0', '10000', 'admin', 'Rbac', 'roleEdit', '', '编辑角色', '', '编辑角色'), ('54', '50', '2', '0', '10000', 'admin', 'Rbac', 'roleEditPost', '', '编辑角色提交', '', '编辑角色提交'), ('55', '50', '2', '0', '10000', 'admin', 'Rbac', 'roleDelete', '', '删除角色', '', '删除角色'), ('56', '50', '1', '0', '10000', 'admin', 'Rbac', 'authorize', '', '设置角色权限', '', '设置角色权限'), ('57', '50', '2', '0', '10000', 'admin', 'Rbac', 'authorizePost', '', '角色授权提交', '', '角色授权提交'), ('58', '0', '1', '0', '10000', 'admin', 'RecycleBin', 'index', '', '回收站', '', '回收站'), ('59', '58', '2', '0', '10000', 'admin', 'RecycleBin', 'restore', '', '回收站还原', '', '回收站还原'), ('60', '58', '2', '0', '10000', 'admin', 'RecycleBin', 'delete', '', '回收站彻底删除', '', '回收站彻底删除'), ('61', '6', '1', '1', '10000', 'admin', 'Route', 'index', '', 'URL美化', '', 'URL规则管理'), ('62', '61', '1', '0', '10000', 'admin', 'Route', 'add', '', '添加路由规则', '', '添加路由规则'), ('63', '61', '2', '0', '10000', 'admin', 'Route', 'addPost', '', '添加路由规则提交', '', '添加路由规则提交'), ('64', '61', '1', '0', '10000', 'admin', 'Route', 'edit', '', '路由规则编辑', '', '路由规则编辑'), ('65', '61', '2', '0', '10000', 'admin', 'Route', 'editPost', '', '路由规则编辑提交', '', '路由规则编辑提交'), ('66', '61', '2', '0', '10000', 'admin', 'Route', 'delete', '', '路由规则删除', '', '路由规则删除'), ('67', '61', '2', '0', '10000', 'admin', 'Route', 'ban', '', '路由规则禁用', '', '路由规则禁用'), ('68', '61', '2', '0', '10000', 'admin', 'Route', 'open', '', '路由规则启用', '', '路由规则启用'), ('69', '61', '2', '0', '10000', 'admin', 'Route', 'listOrder', '', '路由规则排序', '', '路由规则排序'), ('70', '61', '1', '0', '10000', 'admin', 'Route', 'select', '', '选择URL', '', '选择URL'), ('71', '6', '1', '1', '0', 'admin', 'Setting', 'site', '', '网站信息', '', '网站信息'), ('72', '71', '2', '0', '10000', 'admin', 'Setting', 'sitePost', '', '网站信息设置提交', '', '网站信息设置提交'), ('73', '6', '1', '0', '10000', 'admin', 'Setting', 'password', '', '密码修改', '', '密码修改'), ('74', '73', '2', '0', '10000', 'admin', 'Setting', 'passwordPost', '', '密码修改提交', '', '密码修改提交'), ('75', '6', '1', '1', '10000', 'admin', 'Setting', 'upload', '', '上传设置', '', '上传设置'), ('76', '75', '2', '0', '10000', 'admin', 'Setting', 'uploadPost', '', '上传设置提交', '', '上传设置提交'), ('77', '6', '1', '0', '10000', 'admin', 'Setting', 'clearCache', '', '清除缓存', '', '清除缓存'), ('78', '6', '1', '1', '40', 'admin', 'Slide', 'index', '', '幻灯片管理', '', '幻灯片管理'), ('79', '78', '1', '0', '10000', 'admin', 'Slide', 'add', '', '添加幻灯片', '', '添加幻灯片'), ('80', '78', '2', '0', '10000', 'admin', 'Slide', 'addPost', '', '添加幻灯片提交', '', '添加幻灯片提交'), ('81', '78', '1', '0', '10000', 'admin', 'Slide', 'edit', '', '编辑幻灯片', '', '编辑幻灯片'), ('82', '78', '2', '0', '10000', 'admin', 'Slide', 'editPost', '', '编辑幻灯片提交', '', '编辑幻灯片提交'), ('83', '78', '2', '0', '10000', 'admin', 'Slide', 'delete', '', '删除幻灯片', '', '删除幻灯片'), ('84', '78', '1', '0', '10000', 'admin', 'SlideItem', 'index', '', '幻灯片页面列表', '', '幻灯片页面列表'), ('85', '84', '1', '0', '10000', 'admin', 'SlideItem', 'add', '', '幻灯片页面添加', '', '幻灯片页面添加'), ('86', '84', '2', '0', '10000', 'admin', 'SlideItem', 'addPost', '', '幻灯片页面添加提交', '', '幻灯片页面添加提交'), ('87', '84', '1', '0', '10000', 'admin', 'SlideItem', 'edit', '', '幻灯片页面编辑', '', '幻灯片页面编辑'), ('88', '84', '2', '0', '10000', 'admin', 'SlideItem', 'editPost', '', '幻灯片页面编辑提交', '', '幻灯片页面编辑提交'), ('89', '84', '2', '0', '10000', 'admin', 'SlideItem', 'delete', '', '幻灯片页面删除', '', '幻灯片页面删除'), ('90', '84', '2', '0', '10000', 'admin', 'SlideItem', 'ban', '', '幻灯片页面隐藏', '', '幻灯片页面隐藏'), ('91', '84', '2', '0', '10000', 'admin', 'SlideItem', 'cancelBan', '', '幻灯片页面显示', '', '幻灯片页面显示'), ('92', '84', '2', '0', '10000', 'admin', 'SlideItem', 'listOrder', '', '幻灯片页面排序', '', '幻灯片页面排序'), ('93', '6', '1', '1', '10000', 'admin', 'Storage', 'index', '', '文件存储', '', '文件存储'), ('94', '93', '2', '0', '10000', 'admin', 'Storage', 'settingPost', '', '文件存储设置提交', '', '文件存储设置提交'), ('95', '6', '1', '1', '20', 'admin', 'Theme', 'index', '', '模板管理', '', '模板管理'), ('96', '95', '1', '0', '10000', 'admin', 'Theme', 'install', '', '安装模板', '', '安装模板'), ('97', '95', '2', '0', '10000', 'admin', 'Theme', 'uninstall', '', '卸载模板', '', '卸载模板'), ('98', '95', '2', '0', '10000', 'admin', 'Theme', 'installTheme', '', '模板安装', '', '模板安装'), ('99', '95', '2', '0', '10000', 'admin', 'Theme', 'update', '', '模板更新', '', '模板更新'), ('100', '95', '2', '0', '10000', 'admin', 'Theme', 'active', '', '启用模板', '', '启用模板'), ('101', '95', '1', '0', '10000', 'admin', 'Theme', 'files', '', '模板文件列表', '', '启用模板'), ('102', '95', '1', '0', '10000', 'admin', 'Theme', 'fileSetting', '', '模板文件设置', '', '模板文件设置'), ('103', '95', '1', '0', '10000', 'admin', 'Theme', 'fileArrayData', '', '模板文件数组数据列表', '', '模板文件数组数据列表'), ('104', '95', '2', '0', '10000', 'admin', 'Theme', 'fileArrayDataEdit', '', '模板文件数组数据添加编辑', '', '模板文件数组数据添加编辑'), ('105', '95', '2', '0', '10000', 'admin', 'Theme', 'fileArrayDataEditPost', '', '模板文件数组数据添加编辑提交保存', '', '模板文件数组数据添加编辑提交保存'), ('106', '95', '2', '0', '10000', 'admin', 'Theme', 'fileArrayDataDelete', '', '模板文件数组数据删除', '', '模板文件数组数据删除'), ('107', '95', '2', '0', '10000', 'admin', 'Theme', 'settingPost', '', '模板文件编辑提交保存', '', '模板文件编辑提交保存'), ('108', '95', '1', '0', '10000', 'admin', 'Theme', 'dataSource', '', '模板文件设置数据源', '', '模板文件设置数据源'), ('109', '0', '0', '1', '10', 'user', 'AdminIndex', 'default', '', '用户管理', 'group', '用户管理'), ('110', '49', '1', '1', '10000', 'admin', 'User', 'index', '', '管理员', '', '管理员管理'), ('111', '110', '1', '0', '10000', 'admin', 'User', 'add', '', '管理员添加', '', '管理员添加'), ('112', '110', '2', '0', '10000', 'admin', 'User', 'addPost', '', '管理员添加提交', '', '管理员添加提交'), ('113', '110', '1', '0', '10000', 'admin', 'User', 'edit', '', '管理员编辑', '', '管理员编辑'), ('114', '110', '2', '0', '10000', 'admin', 'User', 'editPost', '', '管理员编辑提交', '', '管理员编辑提交'), ('115', '110', '1', '0', '10000', 'admin', 'User', 'userInfo', '', '个人信息', '', '管理员个人信息修改'), ('116', '110', '2', '0', '10000', 'admin', 'User', 'userInfoPost', '', '管理员个人信息修改提交', '', '管理员个人信息修改提交'), ('117', '110', '2', '0', '10000', 'admin', 'User', 'delete', '', '管理员删除', '', '管理员删除'), ('118', '110', '2', '0', '10000', 'admin', 'User', 'ban', '', '停用管理员', '', '停用管理员'), ('119', '110', '2', '0', '10000', 'admin', 'User', 'cancelBan', '', '启用管理员', '', '启用管理员'), ('120', '0', '0', '1', '30', 'portal', 'AdminIndex', 'default', '', '门户管理', 'th', '门户管理'), ('121', '120', '1', '1', '10000', 'portal', 'AdminArticle', 'index', '', '文章管理', '', '文章列表'), ('122', '121', '1', '0', '10000', 'portal', 'AdminArticle', 'add', '', '添加文章', '', '添加文章'), ('123', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'addPost', '', '添加文章提交', '', '添加文章提交'), ('124', '121', '1', '0', '10000', 'portal', 'AdminArticle', 'edit', '', '编辑文章', '', '编辑文章'), ('125', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'editPost', '', '编辑文章提交', '', '编辑文章提交'), ('126', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'delete', '', '文章删除', '', '文章删除'), ('127', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'publish', '', '文章发布', '', '文章发布'), ('128', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'top', '', '文章置顶', '', '文章置顶'), ('129', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'recommend', '', '文章推荐', '', '文章推荐'), ('130', '121', '2', '0', '10000', 'portal', 'AdminArticle', 'listOrder', '', '文章排序', '', '文章排序'), ('131', '120', '1', '1', '10000', 'portal', 'AdminCategory', 'index', '', '分类管理', '', '文章分类列表'), ('132', '131', '1', '0', '10000', 'portal', 'AdminCategory', 'add', '', '添加文章分类', '', '添加文章分类'), ('133', '131', '2', '0', '10000', 'portal', 'AdminCategory', 'addPost', '', '添加文章分类提交', '', '添加文章分类提交'), ('134', '131', '1', '0', '10000', 'portal', 'AdminCategory', 'edit', '', '编辑文章分类', '', '编辑文章分类'), ('135', '131', '2', '0', '10000', 'portal', 'AdminCategory', 'editPost', '', '编辑文章分类提交', '', '编辑文章分类提交'), ('136', '131', '1', '0', '10000', 'portal', 'AdminCategory', 'select', '', '文章分类选择对话框', '', '文章分类选择对话框'), ('137', '131', '2', '0', '10000', 'portal', 'AdminCategory', 'listOrder', '', '文章分类排序', '', '文章分类排序'), ('138', '131', '2', '0', '10000', 'portal', 'AdminCategory', 'delete', '', '删除文章分类', '', '删除文章分类'), ('139', '120', '1', '1', '10000', 'portal', 'AdminPage', 'index', '', '页面管理', '', '页面管理'), ('140', '139', '1', '0', '10000', 'portal', 'AdminPage', 'add', '', '添加页面', '', '添加页面'), ('141', '139', '2', '0', '10000', 'portal', 'AdminPage', 'addPost', '', '添加页面提交', '', '添加页面提交'), ('142', '139', '1', '0', '10000', 'portal', 'AdminPage', 'edit', '', '编辑页面', '', '编辑页面'), ('143', '139', '2', '0', '10000', 'portal', 'AdminPage', 'editPost', '', '编辑页面提交', '', '编辑页面提交'), ('144', '139', '2', '0', '10000', 'portal', 'AdminPage', 'delete', '', '删除页面', '', '删除页面'), ('145', '120', '1', '1', '10000', 'portal', 'AdminTag', 'index', '', '文章标签', '', '文章标签'), ('146', '145', '1', '0', '10000', 'portal', 'AdminTag', 'add', '', '添加文章标签', '', '添加文章标签'), ('147', '145', '2', '0', '10000', 'portal', 'AdminTag', 'addPost', '', '添加文章标签提交', '', '添加文章标签提交'), ('148', '145', '2', '0', '10000', 'portal', 'AdminTag', 'upStatus', '', '更新标签状态', '', '更新标签状态'), ('149', '145', '2', '0', '10000', 'portal', 'AdminTag', 'delete', '', '删除文章标签', '', '删除文章标签'), ('150', '0', '1', '0', '10000', 'user', 'AdminAsset', 'index', '', '资源管理', 'file', '资源管理列表'), ('151', '150', '2', '0', '10000', 'user', 'AdminAsset', 'delete', '', '删除文件', '', '删除文件'), ('152', '109', '0', '1', '10000', 'user', 'AdminIndex', 'default1', '', '用户组', '', '用户组'), ('153', '152', '1', '1', '10000', 'user', 'AdminIndex', 'index', '', '本站用户', '', '本站用户'), ('154', '153', '2', '0', '10000', 'user', 'AdminIndex', 'ban', '', '本站用户拉黑', '', '本站用户拉黑'), ('155', '153', '2', '0', '10000', 'user', 'AdminIndex', 'cancelBan', '', '本站用户启用', '', '本站用户启用'), ('156', '152', '1', '1', '10000', 'user', 'AdminOauth', 'index', '', '第三方用户', '', '第三方用户'), ('157', '156', '2', '0', '10000', 'user', 'AdminOauth', 'delete', '', '删除第三方用户绑定', '', '删除第三方用户绑定'), ('158', '6', '1', '1', '10000', 'user', 'AdminUserAction', 'index', '', '用户操作管理', '', '用户操作管理'), ('159', '158', '1', '0', '10000', 'user', 'AdminUserAction', 'edit', '', '编辑用户操作', '', '编辑用户操作'), ('160', '158', '2', '0', '10000', 'user', 'AdminUserAction', 'editPost', '', '编辑用户操作提交', '', '编辑用户操作提交'), ('161', '158', '1', '0', '10000', 'user', 'AdminUserAction', 'sync', '', '同步用户操作', '', '同步用户操作');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_asset`
--
CREATE TABLE IF NOT EXISTS `cmf_asset` (
`id` bigint(20) unsigned NOT NULL,
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用户id',
`file_size` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '文件大小,单位B',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '上传时间',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:可用,0:不可用',
`download_times` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '下载次数',
`file_key` varchar(64) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '文件惟一码',
`filename` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '文件名',
`file_path` varchar(100) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '文件路径,相对于upload目录,可以为url',
`file_md5` varchar(32) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '文件md5值',
`file_sha1` varchar(40) CHARACTER SET utf8 NOT NULL DEFAULT '',
`suffix` varchar(10) NOT NULL DEFAULT '' COMMENT '文件后缀名,不包括点',
`more` text COMMENT '其它详细信息,JSON格式'
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COMMENT='资源表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_auth_access`
--
CREATE TABLE IF NOT EXISTS `cmf_auth_access` (
`id` bigint(20) unsigned NOT NULL,
`role_id` int(10) unsigned NOT NULL COMMENT '角色',
`rule_name` varchar(100) NOT NULL DEFAULT '' COMMENT '规则唯一英文标识,全小写',
`type` varchar(30) NOT NULL DEFAULT '' COMMENT '权限规则分类,请加应用前缀,如admin_'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='权限授权表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_auth_rule`
--
CREATE TABLE IF NOT EXISTS `cmf_auth_rule` (
`id` int(10) unsigned NOT NULL COMMENT '规则id,自增主键',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '是否有效(0:无效,1:有效)',
`app` varchar(15) NOT NULL COMMENT '规则所属module',
`type` varchar(30) NOT NULL DEFAULT '' COMMENT '权限规则分类,请加应用前缀,如admin_',
`name` varchar(100) NOT NULL DEFAULT '' COMMENT '规则唯一英文标识,全小写',
`param` varchar(100) NOT NULL DEFAULT '' COMMENT '额外url参数',
`title` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '规则描述',
`condition` varchar(200) NOT NULL DEFAULT '' COMMENT '规则附加条件'
) ENGINE=InnoDB AUTO_INCREMENT=154 DEFAULT CHARSET=utf8mb4 COMMENT='权限规则表';
--
-- 转存表中的数据 `cmf_auth_rule`
--
INSERT INTO `cmf_auth_rule` VALUES ('1', '1', 'admin', 'admin_url', 'admin/Hook/index', '', '钩子管理', ''), ('2', '1', 'admin', 'admin_url', 'admin/Hook/plugins', '', '钩子插件管理', ''), ('3', '1', 'admin', 'admin_url', 'admin/Hook/pluginListOrder', '', '钩子插件排序', ''), ('4', '1', 'admin', 'admin_url', 'admin/Hook/sync', '', '同步钩子', ''), ('5', '1', 'admin', 'admin_url', 'admin/Link/index', '', '友情链接', ''), ('6', '1', 'admin', 'admin_url', 'admin/Link/add', '', '添加友情链接', ''), ('7', '1', 'admin', 'admin_url', 'admin/Link/addPost', '', '添加友情链接提交保存', ''), ('8', '1', 'admin', 'admin_url', 'admin/Link/edit', '', '编辑友情链接', ''), ('9', '1', 'admin', 'admin_url', 'admin/Link/editPost', '', '编辑友情链接提交保存', ''), ('10', '1', 'admin', 'admin_url', 'admin/Link/delete', '', '删除友情链接', ''), ('11', '1', 'admin', 'admin_url', 'admin/Link/listOrder', '', '友情链接排序', ''), ('12', '1', 'admin', 'admin_url', 'admin/Link/toggle', '', '友情链接显示隐藏', ''), ('13', '1', 'admin', 'admin_url', 'admin/Mailer/index', '', '邮箱配置', ''), ('14', '1', 'admin', 'admin_url', 'admin/Mailer/indexPost', '', '邮箱配置提交保存', ''), ('15', '1', 'admin', 'admin_url', 'admin/Mailer/template', '', '邮件模板', ''), ('16', '1', 'admin', 'admin_url', 'admin/Mailer/templatePost', '', '邮件模板提交', ''), ('17', '1', 'admin', 'admin_url', 'admin/Mailer/test', '', '邮件发送测试', ''), ('18', '1', 'admin', 'admin_url', 'admin/Menu/index', '', '后台菜单', ''), ('19', '1', 'admin', 'admin_url', 'admin/Menu/lists', '', '所有菜单', ''), ('20', '1', 'admin', 'admin_url', 'admin/Menu/add', '', '后台菜单添加', ''), ('21', '1', 'admin', 'admin_url', 'admin/Menu/addPost', '', '后台菜单添加提交保存', ''), ('22', '1', 'admin', 'admin_url', 'admin/Menu/edit', '', '后台菜单编辑', ''), ('23', '1', 'admin', 'admin_url', 'admin/Menu/editPost', '', '后台菜单编辑提交保存', ''), ('24', '1', 'admin', 'admin_url', 'admin/Menu/delete', '', '后台菜单删除', ''), ('25', '1', 'admin', 'admin_url', 'admin/Menu/listOrder', '', '后台菜单排序', ''), ('26', '1', 'admin', 'admin_url', 'admin/Menu/getActions', '', '导入新后台菜单', ''), ('27', '1', 'admin', 'admin_url', 'admin/Nav/index', '', '导航管理', ''), ('28', '1', 'admin', 'admin_url', 'admin/Nav/add', '', '添加导航', ''), ('29', '1', 'admin', 'admin_url', 'admin/Nav/addPost', '', '添加导航提交保存', ''), ('30', '1', 'admin', 'admin_url', 'admin/Nav/edit', '', '编辑导航', ''), ('31', '1', 'admin', 'admin_url', 'admin/Nav/editPost', '', '编辑导航提交保存', ''), ('32', '1', 'admin', 'admin_url', 'admin/Nav/delete', '', '删除导航', ''), ('33', '1', 'admin', 'admin_url', 'admin/NavMenu/index', '', '导航菜单', ''), ('34', '1', 'admin', 'admin_url', 'admin/NavMenu/add', '', '添加导航菜单', ''), ('35', '1', 'admin', 'admin_url', 'admin/NavMenu/addPost', '', '添加导航菜单提交保存', ''), ('36', '1', 'admin', 'admin_url', 'admin/NavMenu/edit', '', '编辑导航菜单', ''), ('37', '1', 'admin', 'admin_url', 'admin/NavMenu/editPost', '', '编辑导航菜单提交保存', ''), ('38', '1', 'admin', 'admin_url', 'admin/NavMenu/delete', '', '删除导航菜单', ''), ('39', '1', 'admin', 'admin_url', 'admin/NavMenu/listOrder', '', '导航菜单排序', ''), ('40', '1', 'admin', 'admin_url', 'admin/Plugin/default', '', '插件管理', ''), ('41', '1', 'admin', 'admin_url', 'admin/Plugin/index', '', '插件列表', ''), ('42', '1', 'admin', 'admin_url', 'admin/Plugin/toggle', '', '插件启用禁用', ''), ('43', '1', 'admin', 'admin_url', 'admin/Plugin/setting', '', '插件设置', ''), ('44', '1', 'admin', 'admin_url', 'admin/Plugin/settingPost', '', '插件设置提交', ''), ('45', '1', 'admin', 'admin_url', 'admin/Plugin/install', '', '插件安装', ''), ('46', '1', 'admin', 'admin_url', 'admin/Plugin/update', '', '插件更新', ''), ('47', '1', 'admin', 'admin_url', 'admin/Plugin/uninstall', '', '卸载插件', ''), ('48', '1', 'admin', 'admin_url', 'admin/Rbac/index', '', '角色管理', ''), ('49', '1', 'admin', 'admin_url', 'admin/Rbac/roleAdd', '', '添加角色', ''), ('50', '1', 'admin', 'admin_url', 'admin/Rbac/roleAddPost', '', '添加角色提交', ''), ('51', '1', 'admin', 'admin_url', 'admin/Rbac/roleEdit', '', '编辑角色', ''), ('52', '1', 'admin', 'admin_url', 'admin/Rbac/roleEditPost', '', '编辑角色提交', ''), ('53', '1', 'admin', 'admin_url', 'admin/Rbac/roleDelete', '', '删除角色', ''), ('54', '1', 'admin', 'admin_url', 'admin/Rbac/authorize', '', '设置角色权限', ''), ('55', '1', 'admin', 'admin_url', 'admin/Rbac/authorizePost', '', '角色授权提交', ''), ('56', '1', 'admin', 'admin_url', 'admin/RecycleBin/index', '', '回收站', ''), ('57', '1', 'admin', 'admin_url', 'admin/RecycleBin/restore', '', '回收站还原', ''), ('58', '1', 'admin', 'admin_url', 'admin/RecycleBin/delete', '', '回收站彻底删除', ''), ('59', '1', 'admin', 'admin_url', 'admin/Route/index', '', 'URL美化', ''), ('60', '1', 'admin', 'admin_url', 'admin/Route/add', '', '添加路由规则', ''), ('61', '1', 'admin', 'admin_url', 'admin/Route/addPost', '', '添加路由规则提交', ''), ('62', '1', 'admin', 'admin_url', 'admin/Route/edit', '', '路由规则编辑', ''), ('63', '1', 'admin', 'admin_url', 'admin/Route/editPost', '', '路由规则编辑提交', ''), ('64', '1', 'admin', 'admin_url', 'admin/Route/delete', '', '路由规则删除', ''), ('65', '1', 'admin', 'admin_url', 'admin/Route/ban', '', '路由规则禁用', ''), ('66', '1', 'admin', 'admin_url', 'admin/Route/open', '', '路由规则启用', ''), ('67', '1', 'admin', 'admin_url', 'admin/Route/listOrder', '', '路由规则排序', ''), ('68', '1', 'admin', 'admin_url', 'admin/Route/select', '', '选择URL', ''), ('69', '1', 'admin', 'admin_url', 'admin/Setting/default', '', '设置', ''), ('70', '1', 'admin', 'admin_url', 'admin/Setting/site', '', '网站信息', ''), ('71', '1', 'admin', 'admin_url', 'admin/Setting/sitePost', '', '网站信息设置提交', ''), ('72', '1', 'admin', 'admin_url', 'admin/Setting/password', '', '密码修改', ''), ('73', '1', 'admin', 'admin_url', 'admin/Setting/passwordPost', '', '密码修改提交', ''), ('74', '1', 'admin', 'admin_url', 'admin/Setting/upload', '', '上传设置', ''), ('75', '1', 'admin', 'admin_url', 'admin/Setting/uploadPost', '', '上传设置提交', ''), ('76', '1', 'admin', 'admin_url', 'admin/Setting/clearCache', '', '清除缓存', ''), ('77', '1', 'admin', 'admin_url', 'admin/Slide/index', '', '幻灯片管理', ''), ('78', '1', 'admin', 'admin_url', 'admin/Slide/add', '', '添加幻灯片', ''), ('79', '1', 'admin', 'admin_url', 'admin/Slide/addPost', '', '添加幻灯片提交', ''), ('80', '1', 'admin', 'admin_url', 'admin/Slide/edit', '', '编辑幻灯片', ''), ('81', '1', 'admin', 'admin_url', 'admin/Slide/editPost', '', '编辑幻灯片提交', ''), ('82', '1', 'admin', 'admin_url', 'admin/Slide/delete', '', '删除幻灯片', ''), ('83', '1', 'admin', 'admin_url', 'admin/SlideItem/index', '', '幻灯片页面列表', ''), ('84', '1', 'admin', 'admin_url', 'admin/SlideItem/add', '', '幻灯片页面添加', ''), ('85', '1', 'admin', 'admin_url', 'admin/SlideItem/addPost', '', '幻灯片页面添加提交', ''), ('86', '1', 'admin', 'admin_url', 'admin/SlideItem/edit', '', '幻灯片页面编辑', ''), ('87', '1', 'admin', 'admin_url', 'admin/SlideItem/editPost', '', '幻灯片页面编辑提交', ''), ('88', '1', 'admin', 'admin_url', 'admin/SlideItem/delete', '', '幻灯片页面删除', ''), ('89', '1', 'admin', 'admin_url', 'admin/SlideItem/ban', '', '幻灯片页面隐藏', ''), ('90', '1', 'admin', 'admin_url', 'admin/SlideItem/cancelBan', '', '幻灯片页面显示', ''), ('91', '1', 'admin', 'admin_url', 'admin/SlideItem/listOrder', '', '幻灯片页面排序', ''), ('92', '1', 'admin', 'admin_url', 'admin/Storage/index', '', '文件存储', ''), ('93', '1', 'admin', 'admin_url', 'admin/Storage/settingPost', '', '文件存储设置提交', ''), ('94', '1', 'admin', 'admin_url', 'admin/Theme/index', '', '模板管理', ''), ('95', '1', 'admin', 'admin_url', 'admin/Theme/install', '', '安装模板', ''), ('96', '1', 'admin', 'admin_url', 'admin/Theme/uninstall', '', '卸载模板', ''), ('97', '1', 'admin', 'admin_url', 'admin/Theme/installTheme', '', '模板安装', ''), ('98', '1', 'admin', 'admin_url', 'admin/Theme/update', '', '模板更新', ''), ('99', '1', 'admin', 'admin_url', 'admin/Theme/active', '', '启用模板', ''), ('100', '1', 'admin', 'admin_url', 'admin/Theme/files', '', '模板文件列表', ''), ('101', '1', 'admin', 'admin_url', 'admin/Theme/fileSetting', '', '模板文件设置', ''), ('102', '1', 'admin', 'admin_url', 'admin/Theme/fileArrayData', '', '模板文件数组数据列表', ''), ('103', '1', 'admin', 'admin_url', 'admin/Theme/fileArrayDataEdit', '', '模板文件数组数据添加编辑', ''), ('104', '1', 'admin', 'admin_url', 'admin/Theme/fileArrayDataEditPost', '', '模板文件数组数据添加编辑提交保存', ''), ('105', '1', 'admin', 'admin_url', 'admin/Theme/fileArrayDataDelete', '', '模板文件数组数据删除', ''), ('106', '1', 'admin', 'admin_url', 'admin/Theme/settingPost', '', '模板文件编辑提交保存', ''), ('107', '1', 'admin', 'admin_url', 'admin/Theme/dataSource', '', '模板文件设置数据源', ''), ('108', '1', 'admin', 'admin_url', 'admin/User/default', '', '管理组', ''), ('109', '1', 'admin', 'admin_url', 'admin/User/index', '', '管理员', ''), ('110', '1', 'admin', 'admin_url', 'admin/User/add', '', '管理员添加', ''), ('111', '1', 'admin', 'admin_url', 'admin/User/addPost', '', '管理员添加提交', ''), ('112', '1', 'admin', 'admin_url', 'admin/User/edit', '', '管理员编辑', ''), ('113', '1', 'admin', 'admin_url', 'admin/User/editPost', '', '管理员编辑提交', ''), ('114', '1', 'admin', 'admin_url', 'admin/User/userInfo', '', '个人信息', ''), ('115', '1', 'admin', 'admin_url', 'admin/User/userInfoPost', '', '管理员个人信息修改提交', ''), ('116', '1', 'admin', 'admin_url', 'admin/User/delete', '', '管理员删除', ''), ('117', '1', 'admin', 'admin_url', 'admin/User/ban', '', '停用管理员', ''), ('118', '1', 'admin', 'admin_url', 'admin/User/cancelBan', '', '启用管理员', ''), ('119', '1', 'portal', 'admin_url', 'portal/AdminArticle/index', '', '文章管理', ''), ('120', '1', 'portal', 'admin_url', 'portal/AdminArticle/add', '', '添加文章', ''), ('121', '1', 'portal', 'admin_url', 'portal/AdminArticle/addPost', '', '添加文章提交', ''), ('122', '1', 'portal', 'admin_url', 'portal/AdminArticle/edit', '', '编辑文章', ''), ('123', '1', 'portal', 'admin_url', 'portal/AdminArticle/editPost', '', '编辑文章提交', ''), ('124', '1', 'portal', 'admin_url', 'portal/AdminArticle/delete', '', '文章删除', ''), ('125', '1', 'portal', 'admin_url', 'portal/AdminArticle/publish', '', '文章发布', ''), ('126', '1', 'portal', 'admin_url', 'portal/AdminArticle/top', '', '文章置顶', ''), ('127', '1', 'portal', 'admin_url', 'portal/AdminArticle/recommend', '', '文章推荐', ''), ('128', '1', 'portal', 'admin_url', 'portal/AdminArticle/listOrder', '', '文章排序', ''), ('129', '1', 'portal', 'admin_url', 'portal/AdminCategory/index', '', '分类管理', ''), ('130', '1', 'portal', 'admin_url', 'portal/AdminCategory/add', '', '添加文章分类', ''), ('131', '1', 'portal', 'admin_url', 'portal/AdminCategory/addPost', '', '添加文章分类提交', ''), ('132', '1', 'portal', 'admin_url', 'portal/AdminCategory/edit', '', '编辑文章分类', ''), ('133', '1', 'portal', 'admin_url', 'portal/AdminCategory/editPost', '', '编辑文章分类提交', ''), ('134', '1', 'portal', 'admin_url', 'portal/AdminCategory/select', '', '文章分类选择对话框', ''), ('135', '1', 'portal', 'admin_url', 'portal/AdminCategory/listOrder', '', '文章分类排序', ''), ('136', '1', 'portal', 'admin_url', 'portal/AdminCategory/delete', '', '删除文章分类', ''), ('137', '1', 'portal', 'admin_url', 'portal/AdminIndex/default', '', '门户管理', ''), ('138', '1', 'portal', 'admin_url', 'portal/AdminPage/index', '', '页面管理', ''), ('139', '1', 'portal', 'admin_url', 'portal/AdminPage/add', '', '添加页面', ''), ('140', '1', 'portal', 'admin_url', 'portal/AdminPage/addPost', '', '添加页面提交', ''), ('141', '1', 'portal', 'admin_url', 'portal/AdminPage/edit', '', '编辑页面', ''), ('142', '1', 'portal', 'admin_url', 'portal/AdminPage/editPost', '', '编辑页面提交', ''), ('143', '1', 'portal', 'admin_url', 'portal/AdminPage/delete', '', '删除页面', ''), ('144', '1', 'portal', 'admin_url', 'portal/AdminTag/index', '', '文章标签', ''), ('145', '1', 'portal', 'admin_url', 'portal/AdminTag/add', '', '添加文章标签', ''), ('146', '1', 'portal', 'admin_url', 'portal/AdminTag/addPost', '', '添加文章标签提交', ''), ('147', '1', 'portal', 'admin_url', 'portal/AdminTag/upStatus', '', '更新标签状态', ''), ('148', '1', 'portal', 'admin_url', 'portal/AdminTag/delete', '', '删除文章标签', ''), ('149', '1', 'user', 'admin_url', 'user/AdminAsset/index', '', '资源管理', ''), ('150', '1', 'user', 'admin_url', 'user/AdminAsset/delete', '', '删除文件', ''), ('151', '1', 'user', 'admin_url', 'user/AdminIndex/default', '', '用户管理', ''), ('152', '1', 'user', 'admin_url', 'user/AdminIndex/default1', '', '用户组', ''), ('153', '1', 'user', 'admin_url', 'user/AdminIndex/index', '', '本站用户', ''), ('154', '1', 'user', 'admin_url', 'user/AdminIndex/ban', '', '本站用户拉黑', ''), ('155', '1', 'user', 'admin_url', 'user/AdminIndex/cancelBan', '', '本站用户启用', ''), ('156', '1', 'user', 'admin_url', 'user/AdminOauth/index', '', '第三方用户', ''), ('157', '1', 'user', 'admin_url', 'user/AdminOauth/delete', '', '删除第三方用户绑定', ''), ('158', '1', 'user', 'admin_url', 'user/AdminUserAction/index', '', '用户操作管理', ''), ('159', '1', 'user', 'admin_url', 'user/AdminUserAction/edit', '', '编辑用户操作', ''), ('160', '1', 'user', 'admin_url', 'user/AdminUserAction/editPost', '', '编辑用户操作提交', ''), ('161', '1', 'user', 'admin_url', 'user/AdminUserAction/sync', '', '同步用户操作', '');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_comment`
--
CREATE TABLE IF NOT EXISTS `cmf_comment` (
`id` bigint(20) unsigned NOT NULL,
`parent_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '被回复的评论id',
`user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '发表评论的用户id',
`to_user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '被评论的用户id',
`object_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '评论内容 id',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '评论时间',
`delete_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '删除时间',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:已审核,0:未审核',
`type` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '评论类型;1实名评论',
`table_name` varchar(64) NOT NULL DEFAULT '' COMMENT '评论内容所在表,不带表前缀',
`full_name` varchar(50) NOT NULL DEFAULT '' COMMENT '评论者昵称',
`email` varchar(255) NOT NULL DEFAULT '' COMMENT '评论者邮箱',
`path` varchar(255) NOT NULL DEFAULT '' COMMENT '层级关系',
`url` text COMMENT '原文地址',
`content` text COMMENT '评论内容',
`more` text COMMENT '扩展属性'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='评论表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_hook`
--
CREATE TABLE IF NOT EXISTS `cmf_hook` (
`id` int(10) unsigned NOT NULL,
`type` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '钩子类型(1:系统钩子;2:应用钩子;3:模板钩子)',
`once` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否只允许一个插件运行(0:多个;1:一个)',
`name` varchar(30) NOT NULL DEFAULT '' COMMENT '钩子名称',
`hook` varchar(30) NOT NULL DEFAULT '' COMMENT '钩子',
`app` varchar(15) NOT NULL DEFAULT '' COMMENT '应用名(只有应用钩子才用)',
`description` varchar(255) NOT NULL DEFAULT '' COMMENT '描述'
) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=utf8mb4 COMMENT='系统钩子表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_hook_plugin`
--
CREATE TABLE IF NOT EXISTS `cmf_hook_plugin` (
`id` int(10) unsigned NOT NULL,
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`status` tinyint(4) NOT NULL DEFAULT '1' COMMENT '状态(0:禁用,1:启用)',
`hook` varchar(30) NOT NULL DEFAULT '' COMMENT '钩子名',
`plugin` varchar(30) NOT NULL DEFAULT '' COMMENT '插件'
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8mb4 COMMENT='系统钩子插件表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_link`
--
CREATE TABLE IF NOT EXISTS `cmf_link` (
`id` bigint(20) unsigned NOT NULL,
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:显示;0:不显示',
`rating` int(11) NOT NULL DEFAULT '0' COMMENT '友情链接评级',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`description` varchar(255) NOT NULL DEFAULT '' COMMENT '友情链接描述',
`url` varchar(255) NOT NULL DEFAULT '' COMMENT '友情链接地址',
`name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '友情链接名称',
`image` varchar(100) NOT NULL DEFAULT '' COMMENT '友情链接图标',
`target` varchar(10) NOT NULL DEFAULT '' COMMENT '友情链接打开方式',
`rel` varchar(50) NOT NULL DEFAULT '' COMMENT '链接与网站的关系'
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='友情链接表';
--
-- 转存表中的数据 `cmf_link`
--
INSERT INTO `cmf_link` (`id`, `status`, `rating`, `list_order`, `description`, `url`, `name`, `image`, `target`, `rel`) VALUES
(1, 1, 1, 8, '百荣官网', 'http://bronet.cn', '百荣科技', '', '_blank', '');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_nav`
--
CREATE TABLE IF NOT EXISTS `cmf_nav` (
`id` int(10) unsigned NOT NULL,
`is_main` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '是否为主导航;1:是;0:不是',
`name` varchar(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '导航位置名称',
`remark` varchar(255) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '备注'
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COMMENT='前台导航位置表';
--
-- 转存表中的数据 `cmf_nav`
--
INSERT INTO `cmf_nav` (`id`, `is_main`, `name`, `remark`) VALUES
(1, 1, '主导航', '主导航'),
(2, 0, '底部导航', '');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_nav_menu`
--
CREATE TABLE IF NOT EXISTS `cmf_nav_menu` (
`id` int(11) NOT NULL,
`nav_id` int(11) NOT NULL COMMENT '导航 id',
`parent_id` int(11) NOT NULL COMMENT '父 id',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:显示;0:隐藏',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '菜单名称',
`target` varchar(10) NOT NULL DEFAULT '' COMMENT '打开方式',
`href` varchar(100) NOT NULL DEFAULT '' COMMENT '链接',
`icon` varchar(20) NOT NULL DEFAULT '' COMMENT '图标',
`path` varchar(255) NOT NULL DEFAULT '' COMMENT '层级关系'
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='前台导航菜单表';
--
-- 转存表中的数据 `cmf_nav_menu`
--
INSERT INTO `cmf_nav_menu` (`id`, `nav_id`, `parent_id`, `status`, `list_order`, `name`, `target`, `href`, `icon`, `path`) VALUES
(1, 1, 0, 1, 0, '首页', '', 'home', '', '0-1');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_option`
--
CREATE TABLE IF NOT EXISTS `cmf_option` (
`id` bigint(20) unsigned NOT NULL,
`autoload` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '是否自动加载;1:自动加载;0:不自动加载',
`option_name` varchar(64) NOT NULL DEFAULT '' COMMENT '配置名',
`option_value` longtext CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT '配置值'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=COMPACT COMMENT='全站配置表';
--
-- 表的结构 `cmf_plugin`
--
CREATE TABLE IF NOT EXISTS `cmf_plugin` (
`id` int(11) unsigned NOT NULL COMMENT '自增id',
`type` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '插件类型;1:网站;8:微信',
`has_admin` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否有后台管理,0:没有;1:有',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:开启;0:禁用',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '插件安装时间',
`name` varchar(50) NOT NULL DEFAULT '' COMMENT '插件标识名,英文字母(惟一)',
`title` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '插件名称',
`hooks` varchar(255) NOT NULL DEFAULT '' COMMENT '实现的钩子;以“,”分隔',
`author` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '插件作者',
`version` varchar(20) NOT NULL DEFAULT '' COMMENT '插件版本号',
`description` varchar(255) NOT NULL COMMENT '插件描述',
`config` text COMMENT '插件配置'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='插件表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_portal_category`
--
CREATE TABLE IF NOT EXISTS `cmf_portal_category` (
`id` bigint(20) unsigned NOT NULL COMMENT '分类id',
`parent_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '分类父id',
`post_count` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '分类文章数',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:发布,0:不发布',
`delete_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '删除时间',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`name` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '分类名称',
`description` varchar(255) NOT NULL COMMENT '分类描述',
`path` varchar(255) NOT NULL DEFAULT '' COMMENT '分类层级关系路径',
`seo_title` varchar(100) NOT NULL DEFAULT '',
`seo_keywords` varchar(255) NOT NULL DEFAULT '',
`seo_description` varchar(255) NOT NULL DEFAULT '',
`list_tpl` varchar(50) NOT NULL DEFAULT '' COMMENT '分类列表模板',
`one_tpl` varchar(50) NOT NULL DEFAULT '' COMMENT '分类文章页模板',
`more` text COMMENT '扩展属性'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='portal应用 文章分类表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_portal_category_post`
--
CREATE TABLE IF NOT EXISTS `cmf_portal_category_post` (
`id` bigint(20) unsigned NOT NULL,
`post_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '文章id',
`category_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '分类id',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:发布;0:不发布'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='portal应用 分类文章对应表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_portal_post`
--
CREATE TABLE IF NOT EXISTS `cmf_portal_post` (
`id` bigint(20) unsigned NOT NULL,
`parent_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '父级id',
`post_type` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '类型,1:文章;2:页面',
`post_format` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '内容格式;1:html;2:md',
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '发表者用户id',
`post_status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:已发布;0:未发布;',
`comment_status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '评论状态;1:允许;0:不允许',
`is_top` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否置顶;1:置顶;0:不置顶',
`recommended` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否推荐;1:推荐;0:不推荐',
`post_hits` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '查看数',
`post_like` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '点赞数',
`comment_count` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '评论数',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',
`update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
`published_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '发布时间',
`delete_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '删除时间',
`post_title` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT 'post标题',
`post_keywords` varchar(150) NOT NULL DEFAULT '' COMMENT 'seo keywords',
`post_excerpt` varchar(500) NOT NULL COMMENT 'post摘要',
`post_source` varchar(150) NOT NULL DEFAULT '' COMMENT '转载文章的来源',
`post_content` text COMMENT '文章内容',
`post_content_filtered` text COMMENT '处理过的文章内容',
`more` text COMMENT '扩展属性,如缩略图;格式为json'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=COMPACT COMMENT='portal应用 文章表';
--
-- 表的结构 `cmf_portal_tag`
--
CREATE TABLE IF NOT EXISTS `cmf_portal_tag` (
`id` bigint(20) unsigned NOT NULL COMMENT '分类id',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:发布,0:不发布',
`recommended` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否推荐;1:推荐;0:不推荐',
`post_count` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '标签文章数',
`name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '标签名称'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='portal应用 文章标签表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_portal_tag_post`
--
CREATE TABLE IF NOT EXISTS `cmf_portal_tag_post` (
`id` bigint(20) NOT NULL,
`tag_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '标签 id',
`post_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '文章 id',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:发布;0:不发布'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='portal应用 标签文章对应表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_recycle_bin`
--
CREATE TABLE IF NOT EXISTS `cmf_recycle_bin` (
`id` bigint(20) unsigned NOT NULL,
`object_id` int(11) DEFAULT '0' COMMENT '删除内容 id',
`create_time` int(10) unsigned DEFAULT '0' COMMENT '创建时间',
`table_name` varchar(60) DEFAULT '' COMMENT '删除内容所在表名',
`name` varchar(255) DEFAULT '' COMMENT '删除内容名称'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT=' 回收站';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_role`
--
CREATE TABLE IF NOT EXISTS `cmf_role` (
`id` int(10) unsigned NOT NULL,
`parent_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父角色ID',
`status` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '状态;0:禁用;1:正常',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',
`update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
`list_order` float NOT NULL DEFAULT '0' COMMENT '排序',
`name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '角色名称',
`remark` varchar(255) NOT NULL DEFAULT '' COMMENT '备注'
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COMMENT='角色表';
--
-- 转存表中的数据 `cmf_role`
--
INSERT INTO `cmf_role` (`id`, `parent_id`, `status`, `create_time`, `update_time`, `list_order`, `name`, `remark`) VALUES
(1, 0, 1, 1329633709, 1329633709, 0, '超级管理员', '拥有网站最高管理员权限!'),
(2, 0, 1, 1329633709, 1329633709, 0, '普通管理员', '权限由最高管理员分配!');
-- --------------------------------------------------------
--
-- 表的结构 `cmf_role_user`
--
CREATE TABLE IF NOT EXISTS `cmf_role_user` (
`id` bigint(20) unsigned NOT NULL,
`role_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '角色 id',
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用户id'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='用户角色对应表';
--
-- 表的结构 `cmf_route`
--
CREATE TABLE IF NOT EXISTS `cmf_route` (
`id` int(11) NOT NULL COMMENT '路由id',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`status` tinyint(2) NOT NULL DEFAULT '1' COMMENT '状态;1:启用,0:不启用',
`full_url` varchar(255) NOT NULL DEFAULT '' COMMENT '完整url',
`url` varchar(255) NOT NULL DEFAULT '' COMMENT '实际显示的url'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='url路由表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_slide`
--
CREATE TABLE IF NOT EXISTS `cmf_slide` (
`id` int(11) NOT NULL,
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:显示,0不显示',
`delete_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '删除时间',
`name` varchar(50) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '幻灯片分类',
`remark` varchar(255) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '分类备注'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='幻灯片表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_slide_item`
--
CREATE TABLE IF NOT EXISTS `cmf_slide_item` (
`id` int(10) unsigned NOT NULL,
`slide_id` int(11) NOT NULL DEFAULT '0' COMMENT '幻灯片id',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态,1:显示;0:隐藏',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`title` varchar(50) NOT NULL DEFAULT '' COMMENT '幻灯片名称',
`image` varchar(255) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '幻灯片图片',
`url` varchar(255) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '幻灯片链接',
`target` varchar(10) NOT NULL DEFAULT '' COMMENT '友情链接打开方式',
`description` varchar(255) CHARACTER SET utf8 NOT NULL COMMENT '幻灯片描述',
`content` text CHARACTER SET utf8 COMMENT '幻灯片内容',
`more` text COMMENT '链接打开方式'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='幻灯片子项表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_theme`
--
CREATE TABLE IF NOT EXISTS `cmf_theme` (
`id` int(11) NOT NULL,
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '安装时间',
`update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最后升级时间',
`status` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '模板状态,1:正在使用;0:未使用',
`is_compiled` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT '是否为已编译模板',
`theme` varchar(20) NOT NULL DEFAULT '' COMMENT '主题目录名,用于主题的维一标识',
`name` varchar(20) NOT NULL DEFAULT '' COMMENT '主题名称',
`version` varchar(20) NOT NULL DEFAULT '' COMMENT '主题版本号',
`demo_url` varchar(50) NOT NULL DEFAULT '' COMMENT '演示地址,带协议',
`thumbnail` varchar(100) NOT NULL DEFAULT '' COMMENT '缩略图',
`author` varchar(20) NOT NULL DEFAULT '' COMMENT '主题作者',
`author_url` varchar(50) NOT NULL DEFAULT '' COMMENT '作者网站链接',
`lang` varchar(10) NOT NULL DEFAULT '' COMMENT '支持语言',
`keywords` varchar(50) NOT NULL DEFAULT '' COMMENT '主题关键字',
`description` varchar(100) NOT NULL DEFAULT '' COMMENT '主题描述'
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
-- --------------------------------------------------------
--
-- 表的结构 `cmf_theme_file`
--
CREATE TABLE IF NOT EXISTS `cmf_theme_file` (
`id` int(11) NOT NULL,
`is_public` tinyint(4) NOT NULL DEFAULT '0' COMMENT '是否公共的模板文件',
`list_order` float NOT NULL DEFAULT '10000' COMMENT '排序',
`theme` varchar(20) NOT NULL DEFAULT '' COMMENT '模板名称',
`name` varchar(20) NOT NULL DEFAULT '' COMMENT '模板文件名',
`action` varchar(50) NOT NULL DEFAULT '' COMMENT '操作',
`file` varchar(50) NOT NULL DEFAULT '' COMMENT '模板文件,相对于模板根目录,如Portal/index.html',
`description` varchar(100) NOT NULL DEFAULT '' COMMENT '模板文件描述',
`more` text COMMENT '模板更多配置,用户自己后台设置的',
`config_more` text COMMENT '模板更多配置,来源模板的配置文件',
`draft_more` text COMMENT '模板更多配置,用户临时保存的配置'
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
-- --------------------------------------------------------
--
-- 表的结构 `cmf_third_party_user`
--
CREATE TABLE IF NOT EXISTS `cmf_third_party_user` (
`id` bigint(20) unsigned NOT NULL,
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '本站用户id',
`last_login_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最后登录时间',
`expire_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT 'access_token过期时间',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '绑定时间',
`login_times` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '登录次数',
`status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '状态;1:正常;0:禁用',
`nickname` varchar(50) NOT NULL DEFAULT '' COMMENT '用户昵称',
`third_party` varchar(20) NOT NULL DEFAULT '' COMMENT '第三方惟一码',
`app_id` varchar(64) NOT NULL DEFAULT '' COMMENT '第三方应用 id',
`last_login_ip` varchar(15) NOT NULL DEFAULT '' COMMENT '最后登录ip',
`access_token` varchar(512) NOT NULL DEFAULT '' COMMENT '第三方授权码',
`openid` varchar(40) NOT NULL DEFAULT '' COMMENT '第三方用户id',
`union_id` varchar(64) NOT NULL DEFAULT '' COMMENT '第三方用户多个产品中的惟一 id,(如:微信平台)',
`more` text COMMENT '扩展信息'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='第三方用户表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_user`
--
CREATE TABLE IF NOT EXISTS `cmf_user` (
`id` bigint(20) unsigned NOT NULL,
`user_type` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '用户类型;1:admin;2:会员',
`sex` tinyint(2) NOT NULL DEFAULT '0' COMMENT '性别;0:保密,1:男,2:女',
`birthday` int(11) NOT NULL DEFAULT '0' COMMENT '生日',
`last_login_time` int(11) NOT NULL DEFAULT '0' COMMENT '最后登录时间',
`score` int(11) NOT NULL DEFAULT '0' COMMENT '用户积分',
`coin` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '金币',
`create_time` int(11) NOT NULL DEFAULT '0' COMMENT '注册时间',
`user_status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '用户状态;0:禁用,1:正常,2:未验证',
`user_login` varchar(60) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '用户名',
`user_pass` varchar(64) NOT NULL DEFAULT '' COMMENT '登录密码;cmf_password加密',
`user_nickname` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '用户昵称',
`user_email` varchar(100) NOT NULL DEFAULT '' COMMENT '用户登录邮箱',
`user_url` varchar(100) NOT NULL DEFAULT '' COMMENT '用户个人网址',
`avatar` varchar(255) NOT NULL DEFAULT '' COMMENT '用户头像',
`signature` varchar(255) NOT NULL DEFAULT '' COMMENT '个性签名',
`last_login_ip` varchar(15) NOT NULL DEFAULT '' COMMENT '最后登录ip',
`user_activation_key` varchar(60) NOT NULL DEFAULT '' COMMENT '激活码',
`mobile` varchar(20) NOT NULL DEFAULT '' COMMENT '用户手机号'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_user_action_log`
--
CREATE TABLE IF NOT EXISTS `cmf_user_action_log` (
`id` bigint(20) unsigned NOT NULL,
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用户id',
`count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '访问次数',
`last_visit_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最后访问时间',
`object` varchar(100) NOT NULL DEFAULT '' COMMENT '访问对象的id,格式:不带前缀的表名+id;如posts1表示xx_posts表里id为1的记录',
`action` varchar(50) NOT NULL DEFAULT '' COMMENT '操作名称;格式:应用名+控制器+操作名,也可自己定义格式只要不发生冲突且惟一;',
`ip` varchar(15) NOT NULL DEFAULT '' COMMENT '用户ip'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='访问记录表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_user_favorite`
--
CREATE TABLE IF NOT EXISTS `cmf_user_favorite` (
`id` bigint(20) unsigned NOT NULL,
`user_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '用户 id',
`title` varchar(100) NOT NULL DEFAULT '' COMMENT '收藏内容的标题',
`url` varchar(255) CHARACTER SET utf8 DEFAULT '' COMMENT '收藏内容的原文地址,不带域名',
`description` varchar(500) CHARACTER SET utf8 DEFAULT '' COMMENT '收藏内容的描述',
`table_name` varchar(64) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '收藏实体以前所在表,不带前缀',
`object_id` int(10) unsigned DEFAULT '0' COMMENT '收藏内容原来的主键id',
`create_time` int(10) unsigned DEFAULT '0' COMMENT '收藏时间'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户收藏表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_user_login_attempt`
--
CREATE TABLE IF NOT EXISTS `cmf_user_login_attempt` (
`id` bigint(20) unsigned NOT NULL,
`login_attempts` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '尝试次数',
`attempt_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '尝试登录时间',
`locked_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '锁定时间',
`ip` varchar(15) NOT NULL DEFAULT '' COMMENT '用户 ip',
`account` varchar(100) NOT NULL DEFAULT '' COMMENT '用户账号,手机号,邮箱或用户名'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=COMPACT COMMENT='用户登录尝试表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_user_token`
--
CREATE TABLE IF NOT EXISTS `cmf_user_token` (
`id` bigint(20) NOT NULL,
`user_id` bigint(20) NOT NULL DEFAULT '0' COMMENT '用户id',
`expire_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT ' 过期时间',
`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',
`token` varchar(64) NOT NULL DEFAULT '' COMMENT 'token',
`device_type` varchar(10) NOT NULL DEFAULT '' COMMENT '设备类型;mobile,android,iphone,ipad,web,pc,mac,wxapp'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户客户端登录 token 表';
-- --------------------------------------------------------
--
-- 表的结构 `cmf_verification_code`
--
CREATE TABLE IF NOT EXISTS `cmf_verification_code` (
`id` bigint(20) unsigned NOT NULL COMMENT '表id',
`count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '当天已经发送成功的次数',
`send_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最后发送成功时间',
`expire_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '验证码过期时间',
`code` varchar(8) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '最后发送成功的验证码',
`account` varchar(100) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '手机号或者邮箱'
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='手机邮箱数字验证码表';
--
-- Indexes for dumped tables
--
--
-- Indexes for table `cmf_admin_menu`
--
ALTER TABLE `cmf_admin_menu`
ADD PRIMARY KEY (`id`),
ADD KEY `status` (`status`),
ADD KEY `parentid` (`parent_id`),
ADD KEY `model` (`controller`);
--
-- Indexes for table `cmf_asset`
--
ALTER TABLE `cmf_asset`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_auth_access`
--
ALTER TABLE `cmf_auth_access`
ADD PRIMARY KEY (`id`),
ADD KEY `role_id` (`role_id`),
ADD KEY `rule_name` (`rule_name`) USING BTREE;
--
-- Indexes for table `cmf_auth_rule`
--
ALTER TABLE `cmf_auth_rule`
ADD PRIMARY KEY (`id`),
ADD UNIQUE KEY `name` (`name`) USING BTREE,
ADD KEY `module` (`app`,`status`,`type`);
--
-- Indexes for table `cmf_comment`
--
ALTER TABLE `cmf_comment`
ADD PRIMARY KEY (`id`),
ADD KEY `comment_post_ID` (`object_id`),
ADD KEY `comment_approved_date_gmt` (`status`),
ADD KEY `comment_parent` (`parent_id`),
ADD KEY `table_id_status` (`table_name`,`object_id`,`status`),
ADD KEY `createtime` (`create_time`);
--
-- Indexes for table `cmf_hook`
--
ALTER TABLE `cmf_hook`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_hook_plugin`
--
ALTER TABLE `cmf_hook_plugin`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_link`
--
ALTER TABLE `cmf_link`
ADD PRIMARY KEY (`id`),
ADD KEY `link_visible` (`status`);
--
-- Indexes for table `cmf_nav`
--
ALTER TABLE `cmf_nav`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_nav_menu`
--
ALTER TABLE `cmf_nav_menu`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_option`
--
ALTER TABLE `cmf_option`
ADD PRIMARY KEY (`id`),
ADD UNIQUE KEY `option_name` (`option_name`);
--
-- Indexes for table `cmf_plugin`
--
ALTER TABLE `cmf_plugin`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_portal_category`
--
ALTER TABLE `cmf_portal_category`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_portal_category_post`
--
ALTER TABLE `cmf_portal_category_post`
ADD PRIMARY KEY (`id`),
ADD KEY `term_taxonomy_id` (`category_id`);
--
-- Indexes for table `cmf_portal_post`
--
ALTER TABLE `cmf_portal_post`
ADD PRIMARY KEY (`id`),
ADD KEY `type_status_date` (`post_type`,`post_status`,`create_time`,`id`),
ADD KEY `post_parent` (`parent_id`),
ADD KEY `post_author` (`user_id`),
ADD KEY `post_date` (`create_time`) USING BTREE;
--
-- Indexes for table `cmf_portal_tag`
--
ALTER TABLE `cmf_portal_tag`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_portal_tag_post`
--
ALTER TABLE `cmf_portal_tag_post`
ADD PRIMARY KEY (`id`),
ADD KEY `term_taxonomy_id` (`post_id`);
--
-- Indexes for table `cmf_recycle_bin`
--
ALTER TABLE `cmf_recycle_bin`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_role`
--
ALTER TABLE `cmf_role`
ADD PRIMARY KEY (`id`),
ADD KEY `parentId` (`parent_id`),
ADD KEY `status` (`status`);
--
-- Indexes for table `cmf_role_user`
--
ALTER TABLE `cmf_role_user`
ADD PRIMARY KEY (`id`),
ADD KEY `group_id` (`role_id`),
ADD KEY `user_id` (`user_id`);
--
-- Indexes for table `cmf_route`
--
ALTER TABLE `cmf_route`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_slide`
--
ALTER TABLE `cmf_slide`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_slide_item`
--
ALTER TABLE `cmf_slide_item`
ADD PRIMARY KEY (`id`),
ADD KEY `slide_cid` (`slide_id`);
--
-- Indexes for table `cmf_theme`
--
ALTER TABLE `cmf_theme`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_theme_file`
--
ALTER TABLE `cmf_theme_file`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_third_party_user`
--
ALTER TABLE `cmf_third_party_user`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_user`
--
ALTER TABLE `cmf_user`
ADD PRIMARY KEY (`id`),
ADD KEY `user_login` (`user_login`),
ADD KEY `user_nickname` (`user_nickname`);
--
-- Indexes for table `cmf_user_action_log`
--
ALTER TABLE `cmf_user_action_log`
ADD PRIMARY KEY (`id`),
ADD KEY `user_object_action` (`user_id`,`object`,`action`),
ADD KEY `user_object_action_ip` (`user_id`,`object`,`action`,`ip`);
--
-- Indexes for table `cmf_user_favorite`
--
ALTER TABLE `cmf_user_favorite`
ADD PRIMARY KEY (`id`),
ADD KEY `uid` (`user_id`);
--
-- Indexes for table `cmf_user_login_attempt`
--
ALTER TABLE `cmf_user_login_attempt`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_user_token`
--
ALTER TABLE `cmf_user_token`
ADD PRIMARY KEY (`id`);
--
-- Indexes for table `cmf_verification_code`
--
ALTER TABLE `cmf_verification_code`
ADD PRIMARY KEY (`id`);
--
-- AUTO_INCREMENT for dumped tables
--
--
-- AUTO_INCREMENT for table `cmf_admin_menu`
--
ALTER TABLE `cmf_admin_menu`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=154;
--
-- AUTO_INCREMENT for table `cmf_asset`
--
ALTER TABLE `cmf_asset`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=5;
--
-- AUTO_INCREMENT for table `cmf_auth_access`
--
ALTER TABLE `cmf_auth_access`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_auth_rule`
--
ALTER TABLE `cmf_auth_rule`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '规则id,自增主键',AUTO_INCREMENT=154;
--
-- AUTO_INCREMENT for table `cmf_comment`
--
ALTER TABLE `cmf_comment`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_hook`
--
ALTER TABLE `cmf_hook`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=24;
--
-- AUTO_INCREMENT for table `cmf_hook_plugin`
--
ALTER TABLE `cmf_hook_plugin`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=10;
--
-- AUTO_INCREMENT for table `cmf_link`
--
ALTER TABLE `cmf_link`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=2;
--
-- AUTO_INCREMENT for table `cmf_nav`
--
ALTER TABLE `cmf_nav`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=4;
--
-- AUTO_INCREMENT for table `cmf_nav_menu`
--
ALTER TABLE `cmf_nav_menu`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=17;
--
-- AUTO_INCREMENT for table `cmf_option`
--
ALTER TABLE `cmf_option`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=7;
--
-- AUTO_INCREMENT for table `cmf_plugin`
--
ALTER TABLE `cmf_plugin`
MODIFY `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增id',AUTO_INCREMENT=14;
--
-- AUTO_INCREMENT for table `cmf_portal_category`
--
ALTER TABLE `cmf_portal_category`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '分类id',AUTO_INCREMENT=8;
--
-- AUTO_INCREMENT for table `cmf_portal_category_post`
--
ALTER TABLE `cmf_portal_category_post`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=117;
--
-- AUTO_INCREMENT for table `cmf_portal_post`
--
ALTER TABLE `cmf_portal_post`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=32;
--
-- AUTO_INCREMENT for table `cmf_portal_tag`
--
ALTER TABLE `cmf_portal_tag`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '分类id',AUTO_INCREMENT=4;
--
-- AUTO_INCREMENT for table `cmf_portal_tag_post`
--
ALTER TABLE `cmf_portal_tag_post`
MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_recycle_bin`
--
ALTER TABLE `cmf_recycle_bin`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=25;
--
-- AUTO_INCREMENT for table `cmf_role`
--
ALTER TABLE `cmf_role`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=3;
--
-- AUTO_INCREMENT for table `cmf_role_user`
--
ALTER TABLE `cmf_role_user`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=11;
--
-- AUTO_INCREMENT for table `cmf_route`
--
ALTER TABLE `cmf_route`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '路由id',AUTO_INCREMENT=12;
--
-- AUTO_INCREMENT for table `cmf_slide`
--
ALTER TABLE `cmf_slide`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_slide_item`
--
ALTER TABLE `cmf_slide_item`
MODIFY `id` int(10) unsigned NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_theme`
--
ALTER TABLE `cmf_theme`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=19;
--
-- AUTO_INCREMENT for table `cmf_theme_file`
--
ALTER TABLE `cmf_theme_file`
MODIFY `id` int(11) NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=105;
--
-- AUTO_INCREMENT for table `cmf_third_party_user`
--
ALTER TABLE `cmf_third_party_user`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_user`
--
ALTER TABLE `cmf_user`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=8;
--
-- AUTO_INCREMENT for table `cmf_user_action_log`
--
ALTER TABLE `cmf_user_action_log`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=11;
--
-- AUTO_INCREMENT for table `cmf_user_favorite`
--
ALTER TABLE `cmf_user_favorite`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=6;
--
-- AUTO_INCREMENT for table `cmf_user_login_attempt`
--
ALTER TABLE `cmf_user_login_attempt`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT;
--
-- AUTO_INCREMENT for table `cmf_user_token`
--
ALTER TABLE `cmf_user_token`
MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=3;
--
-- AUTO_INCREMENT for table `cmf_verification_code`
--
ALTER TABLE `cmf_verification_code`
MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '表id',AUTO_INCREMENT=9;
ALTER TABLE `cmf_route` ADD `type` TINYINT NOT NULL DEFAULT '1' COMMENT 'URL规则类型;1:用户自定义;2:别名添加' AFTER `status`;
-- 2017-09-12 12:38 更改字段长度
ALTER TABLE `cmf_hook` CHANGE `hook` `hook` VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '钩子';
ALTER TABLE `cmf_hook` CHANGE `name` `name` VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '钩子名称';
ALTER TABLE `cmf_hook_plugin` CHANGE `hook` `hook` VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT '钩子名';
INSERT INTO `cmf_hook` VALUES ('1', '1', '0', '应用初始化', 'app_init', 'cmf', '应用初始化'), ('2', '1', '0', '应用开始', 'app_begin', 'cmf', '应用开始'), ('3', '1', '0', '模块初始化', 'module_init', 'cmf', '模块初始化'), ('4', '1', '0', '控制器开始', 'action_begin', 'cmf', '控制器开始'), ('5', '1', '0', '视图输出过滤', 'view_filter', 'cmf', '视图输出过滤'), ('6', '1', '0', '应用结束', 'app_end', 'cmf', '应用结束'), ('7', '1', '0', '日志write方法', 'log_write', 'cmf', '日志write方法'), ('8', '1', '0', '输出结束', 'response_end', 'cmf', '输出结束'), ('9', '1', '0', '后台控制器初始化', 'admin_init', 'cmf', '后台控制器初始化'), ('10', '1', '0', '前台控制器初始化', 'home_init', 'cmf', '前台控制器初始化'), ('11', '1', '1', '发送手机验证码', 'send_mobile_verification_code', 'cmf', '发送手机验证码'), ('12', '3', '0', '模板 body标签开始', 'body_start', '', '模板 body标签开始'), ('13', '3', '0', '模板 head标签结束前', 'before_head_end', '', '模板 head标签结束前'), ('14', '3', '0', '模板底部开始', 'footer_start', '', '模板底部开始'), ('15', '3', '0', '模板底部开始之前', 'before_footer', '', '模板底部开始之前'), ('16', '3', '0', '模板底部结束之前', 'before_footer_end', '', '模板底部结束之前'), ('17', '3', '0', '模板 body 标签结束之前', 'before_body_end', '', '模板 body 标签结束之前'), ('18', '3', '0', '模板左边栏开始', 'left_sidebar_start', '', '模板左边栏开始'), ('19', '3', '0', '模板左边栏结束之前', 'before_left_sidebar_end', '', '模板左边栏结束之前'), ('20', '3', '0', '模板右边栏开始', 'right_sidebar_start', '', '模板右边栏开始'), ('21', '3', '0', '模板右边栏结束之前', 'before_right_sidebar_end', '', '模板右边栏结束之前'), ('22', '3', '1', '评论区', 'comment', '', '评论区'), ('23', '3', '1', '留言区', 'guestbook', '', '留言区'), ('24', '2', '0', '后台首页仪表盘', 'admin_dashboard', 'admin', '后台首页仪表盘'), ('25', '4', '0', '后台模板 head标签结束前', 'admin_before_head_end', '', '后台模板 head标签结束前'), ('26', '4', '0', '后台模板 body 标签结束之前', 'admin_before_body_end', '', '后台模板 body 标签结束之前'), ('27', '2', '0', '后台登录页面', 'admin_login', 'admin', '后台登录页面'), ('28', '1', '1', '前台模板切换', 'switch_theme', 'cmf', '前台模板切换'), ('29', '3', '0', '主要内容之后', 'after_content', '', '主要内容之后'), ('30', '2', '0', '文章显示之前', 'portal_before_assign_article', 'portal', '文章显示之前'), ('31', '2', '0', '后台文章保存之后', 'portal_admin_after_save_article', 'portal', '后台文章保存之后');
ALTER TABLE `cmf_plugin` ADD `demo_url` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '演示地址,带协议' AFTER `title`;
ALTER TABLE `cmf_plugin` ADD `author_url` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '作者网站链接' AFTER `author`;
--
-- 2017-07-06 11:10 增加用户操作表
--
DROP TABLE IF EXISTS `cmf_user_action`;
CREATE TABLE `cmf_user_action` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`score` int(11) NOT NULL DEFAULT '0' COMMENT '更改积分,可以为负',
`coin` int(11) NOT NULL DEFAULT '0' COMMENT '更改金币,可以为负',
`reward_number` int(11) NOT NULL DEFAULT '0' COMMENT '奖励次数',
`cycle_type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '周期类型;0:不限;1:按天;2:按小时;3:永久',
`cycle_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '周期时间值',
`name` varchar(50) NOT NULL DEFAULT '' COMMENT '用户操作名称',
`action` varchar(50) NOT NULL DEFAULT '' COMMENT '用户操作名称',
`app` varchar(50) NOT NULL DEFAULT '' COMMENT '操作所在应用名或插件名等',
`url` text COMMENT '执行操作的url',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户操作表';
--
-- 2017-07-06 11:10 增加用户操作积分等奖励日志表
--
DROP TABLE IF EXISTS `cmf_user_score_log`;
CREATE TABLE `cmf_user_score_log` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` bigint(20) NOT NULL DEFAULT '0' COMMENT '用户 id',
`create_time` int(11) NOT NULL DEFAULT '0' COMMENT '创建时间',
`action` varchar(50) NOT NULL DEFAULT '' COMMENT '用户操作名称',
`score` int(11) NOT NULL DEFAULT '0' COMMENT '更改积分,可以为负',
`coin` int(11) NOT NULL DEFAULT '0' COMMENT '更改金币,可以为负',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户操作积分等奖励日志表';
--
-- 2017-08-07 12:02:01 增加post_excerpt默认值
--
ALTER TABLE `cmf_portal_post` CHANGE `post_excerpt` `post_excerpt` VARCHAR(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '' COMMENT 'post摘要';
-- 2017-09-06 10:35更正 admin_menu表list_order 字段类型
ALTER TABLE `cmf_admin_menu` CHANGE `list_order` `list_order` FLOAT NOT NULL DEFAULT '10000' COMMENT '排序';
-- 2017-09-07 13:35 增加用户表 more 字段
ALTER TABLE `cmf_user` ADD `more` TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '扩展属性' AFTER `mobile`;
<?php
// +----------------------------------------------------------------------
// | bronet [ 以客户为中心 以奋斗者为本 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2017 http://www.bronet.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老猫 <bronet@126.com>
// +----------------------------------------------------------------------
return [
'ACCEPT' => 'ACCEPT'
];
\ No newline at end of file
<?php
// +----------------------------------------------------------------------
// | bronet [ 以客户为中心 以奋斗者为本 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013-2017 http://www.bronet.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 老猫 <bronet@126.com>
// +----------------------------------------------------------------------
return [
'ACCEPT' => '接 受'
];
\ No newline at end of file
<!doctype html>
<html>
<head>
<include file="public/head" />
</head>
<body>
<div class="wrap">
<include file="public/header" />
<div class="section">
<div class="main">
<pre class="agreement">bronet软件使用协议
版权所有 ©2013-{:date("Y")},bronet开源社区
感谢您选择bronet内容管理框架, 希望我们的产品能够帮您把网站发展的更快、更好、更强!
bronet遵循Apache Lisense 2.0开源协议发布,并提供免费使用。
bronet建站系统由简约风网络科技(以下简称简约风,官网http://www.bronet.cn)发起并开源发布。
简约风网络科技包含以下网站:
bronet官网: http://www.bronet.cn
bronet免责声明
1、使用bronet构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果,bronet官方不承担任何责任。
2、您一旦安装使用bronet,即被视为完全理解并接受本协议的各项条款,在享有上述条款授予的权力的同时,受到相关的约束和限制。</pre>
</div>
<div class="bottom text-center">
<a href="{:url('index/step2')}" class="btn btn-primary">{:lang('ACCEPT')}</a>
</div>
</div>
</div>
<include file="public/footer" />
</body>
</html>
\ No newline at end of file
<div class="footer">
&copy; 2013-{:date('Y')} <a href="http://www.bronet.cn" target="_blank">bronet Team</a>
</div>
\ No newline at end of file
<meta charset="utf-8" />
<title>bronet安装</title>
<link rel="stylesheet" href="__STATIC__/install/simpleboot/themes/flat/theme.min.css" />
<link rel="stylesheet" href="__STATIC__/install/css/install.css" />
<link rel="stylesheet" href="__STATIC__/font-awesome/css/font-awesome.min.css" type="text/css">
<div class="header">
<h1 class="logo">bronet 安装向导</h1>
<div class="version">{$Think.BRONET_VERSION}</div>
</div>
\ No newline at end of file
<!doctype html>
<html>
<head>
<include file="public/head"/>
</head>
<body>
<div class="wrap">
<include file="public/header"/>
<section class="section">
<div class="step">
<ul class="unstyled">
<li class="current"><em>1</em>检测环境</li>
<li><em>2</em>创建数据</li>
<li><em>3</em>完成安装</li>
</ul>
</div>
<div class="server">
<table width="100%">
<tr>
<td class="td1">环境检测</td>
<td class="td1" width="25%">推荐配置</td>
<td class="td1" width="25%">当前状态</td>
<td class="td1" width="25%">最低要求</td>
</tr>
<tr>
<td>操作系统</td>
<td>类UNIX</td>
<td><i class="fa fa-check correct"></i> {$os}</td>
<td>不限制</td>
</tr>
<tr>
<td>PHP版本</td>
<td>>5.6.x</td>
<td><i class="fa fa-check correct"></i> {$phpversion}</td>
<td>5.3.0</td>
</tr>
<!-- 模块检测 -->
<tr>
<td class="td1" colspan="4">
模块检测
</td>
</tr>
<tr>
<td>session</td>
<td>开启</td>
<td>
{$session}
</td>
<td>开启</td>
</tr>
<tr>
<td>
PDO
<a href="https://www.baidu.com/s?wd=开启PDO,PDO_MYSQL扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$pdo}
</td>
<td>开启</td>
</tr>
<tr>
<td>
PDO_MySQL
<a href="https://www.baidu.com/s?wd=开启PDO,PDO_MYSQL扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$pdo_mysql}
</td>
<td>开启</td>
</tr>
<tr>
<td>
CURL
<a href="https://www.baidu.com/s?wd=开启PHP CURL扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$curl}
</td>
<td>开启</td>
</tr>
<tr>
<td>
GD
<a href="https://www.baidu.com/s?wd=开启PHP GD扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$gd}
</td>
<td>开启</td>
</tr>
<tr>
<td>
MBstring
<a href="https://www.baidu.com/s?wd=开启PHP MBstring扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$mbstring}
</td>
<td>开启</td>
</tr>
<tr>
<td>
fileinfo
<a href="https://www.baidu.com/s?wd=开启PHP fileinfo扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>开启</td>
<td>
{$fileinfo}
</td>
<td>开启</td>
</tr>
<notempty name="show_always_populate_raw_post_data_tip">
<tr>
<td>
$HTTP_RAW_POST_DATA关闭检测
<a href="https://www.baidu.com/s?wd=开启PHP fileinfo扩展" target="_blank">
<i class="fa fa-question-circle question"></i>
</a>
</td>
<td>关闭</td>
<td>
{$always_populate_raw_post_data}
</td>
<td>关闭</td>
</tr>
<tr>
<td>$HTTP_RAW_POST_DATA未关闭解决</td>
<td colspan="3">
<pre>
;php.ini 找到 always_populate_raw_post_data设置如下:
always_populate_raw_post_data = -1
</pre>
</td>
</tr>
</notempty>
<!-- 大小限制检测 -->
<tr>
<td class="td1" colspan="4">
大小限制检测
</td>
</tr>
<tr>
<td>附件上传</td>
<td>>2M</td>
<td>
{$upload_size}
</td>
<td>不限制</td>
</tr>
</table>
<table width="100%">
<tr>
<td class="td1">目录、文件权限检查</td>
<td class="td1" width="25%">写入</td>
<td class="td1" width="25%">读取</td>
</tr>
<foreach name="folders" item="vo" key="dir">
<tr>
<td>
{$dir}
</td>
<td>
<if condition="$vo['w']">
<i class="fa fa-check correct"></i> 可写
<else/>
<i class="fa fa-remove error"></i> 不可写
</if>
</td>
<td>
<if condition="$vo['r']">
<i class="fa fa-check correct"></i> 可读
<else/>
<i class="fa fa-remove error"></i> 不可读
</if>
</td>
</tr>
</foreach>
</table>
</div>
<div class="bottom text-center">
<a href="{:url('index/step2')}" class="btn btn-primary">重新检测</a>
<a href="{:url('index/step3')}" class="btn btn-primary">下一步</a>
</div>
</section>
</div>
<include file="public/footer"/>
</body>
</html>
\ No newline at end of file
<!doctype html>
<html>
<head>
<include file="public/head"/>
</head>
<body>
<div class="wrap">
<include file="public/header"/>
<section class="section">
<div class="step">
<ul class="unstyled">
<li class="on"><em>1</em>检测环境</li>
<li class="current"><em>2</em>创建数据</li>
<li><em>3</em>完成安装</li>
</ul>
</div>
<form id="js-install-form" action="{:url('index/step4')}" method="post">
<input type="hidden" name="force" value="0"/>
<div class="server">
<table width="100%">
<tr>
<td class="td1" width="100">数据库信息</td>
<td class="td1" width="200">&nbsp;</td>
<td class="td1">&nbsp;</td>
</tr>
<tr>
<td class="text-left">数据库服务器:</td>
<td><input type="text" name="dbhost" id="dbhost" value="127.0.0.1" class="input"></td>
<td>
<div id="js-install-tip-dbhost">
<span class="gray">数据库服务器地址,一般为127.0.0.1或localhost</span>
</div>
</td>
</tr>
<tr>
<td class="text-left">数据库端口:</td>
<td><input type="text" name="dbport" id="dbport" value="3306" class="input"></td>
<td>
<div id="js-install-tip-dbport">
<span class="gray">数据库服务器端口,一般为3306</span>
</div>
</td>
</tr>
<tr>
<td class="text-left">数据库用户名:</td>
<td><input type="text" name="dbuser" id="dbuser" value="root" class="input"></td>
<td>
<div id="js-install-tip-dbuser"></div>
</td>
</tr>
<tr>
<td class="text-left">数据库密码:</td>
<td>
<input type="password" name="dbpw" id="dbpw" value="" class="input" autoComplete="off"
onblur="TestDbPwd()">
</td>
<td>
<div id="js-install-tip-dbpw"></div>
</td>
</tr>
<tr>
<td class="text-left">数据库名:</td>
<td><input type="text" name="dbname" id="dbname" value="bronet5" class="input"></td>
<td>
<div id="js-install-tip-dbname">
<span class="gray">最好小写字母</span>
</div>
</td>
</tr>
<tr>
<td class="text-left">数据库表前缀:</td>
<td><input type="text" name="dbprefix" id="dbprefix" value="bro_" class="input"></td>
<td>
<div id="js-install-tip-dbprefix">
<span class="gray">建议使用默认,同一数据库安装多个项目时需修改</span>
</div>
</td>
</tr>
<tr>
<td class="text-left">数据库编码:</td>
<td>
<select type="text" name="dbcharset" id="dbcharset" value="" class="input">
<option value="utf8mb4">utf8mb4</option>
<option value="utf8">utf8</option>
</select>
</td>
<td>
<div id="js-install-tip-dbcharset">
<span class="gray">如果您的服务器是虚拟空间不支持uft8mb4,请选择 utf8</span>
</div>
</td>
</tr>
</table>
<table width="100%">
<tr>
<td class="td1" width="100">网站配置</td>
<td class="td1" width="200">&nbsp;</td>
<td class="td1">&nbsp;</td>
</tr>
<tr>
<td class="text-left">网站名称:</td>
<td><input type="text" name="sitename" value="bronet内容管理框架" class="input"></td>
<td>
<div id="js-install-tip-sitename"></div>
</td>
</tr>
<tr>
<td class="text-left">关键词:</td>
<td>
<input type="text" name="sitekeywords"
value="bronet,php,内容管理框架,cmf,cms,简约风, simplewind,framework" class="input"
autoComplete="off">
</td>
<td>
<div id="js-install-tip-sitekeywords"></div>
</td>
</tr>
<tr>
<td class="text-left">描述:</td>
<td>
<input type="text" name="siteinfo" class="input" value="bronet是简约风网络科技发布的一款用于快速开发的内容管理框架">
</td>
<td>
<div id="js-install-tip-siteinfo"></div>
</td>
</tr>
</table>
<table width="100%">
<tr>
<td class="td1" width="100">创始人信息</td>
<td class="td1" width="200">&nbsp;</td>
<td class="td1">&nbsp;</td>
</tr>
<tr>
<td class="text-left">管理员帐号:</td>
<td><input type="text" name="manager" value="bronet" class="input"></td>
<td>
<div id="js-install-tip-manager"></div>
</td>
</tr>
<tr>
<td class="text-left">密码:</td>
<td>
<input type="password" name="manager_pwd" id="js-manager-pwd" class="input"
autoComplete="off">
</td>
<td>
<div id="js-install-tip-manager_pwd"></div>
</td>
</tr>
<tr>
<td class="text-left">重复密码:</td>
<td>
<input type="password" name="manager_ckpwd" class="input" autoComplete="off">
</td>
<td>
<div id="js-install-tip-manager_ckpwd"></div>
</td>
</tr>
<tr>
<td class="text-left">Email:</td>
<td><input type="text" name="manager_email" class="input" value=""></td>
<td>
<div id="js-install-tip-manager_email"></div>
</td>
</tr>
</table>
<div id="js-response-tips" style="display: none;"></div>
</div>
<div class="bottom text-center">
<a href="{:url('index/step2')}" class="btn btn-primary">上一步</a>
<button type="submit" class="btn btn-primary">创建数据</button>
</div>
</form>
</section>
<script src="__STATIC__/js/jquery.js"></script>
<script src="__STATIC__/js/validate.js"></script>
<script src="__STATIC__/js/ajaxForm.js"></script>
<script>
function TestDbPwd() {
var dbHost = $('#dbhost').val();
var dbUser = $('#dbuser').val();
var dbPwd = $('#dbpw').val();
var dbName = $('#dbname').val();
var dbPort = $('#dbport').val();
data = {
'hostname': dbHost,
'username': dbUser,
'password': dbPwd,
'hostport': dbPort
};
var url = "{:url('index/testDbPwd')}";
$.ajax({
type: "POST",
url: url,
data: data,
beforeSend: function () {
},
success: function (msg) {
if (msg) {
} else {
$('#dbpw').val("");
$('#js-install-tip-dbpw').html('<span for="dbname" generated="true" class="tips-error" style="">数据库链接配置失败</span>');
}
},
complete: function () {
},
error: function () {
$('#js-install-tip-dbpw').html('<span for="dbname" generated="true" class="tips-error" style="">数据库链接配置失败</span>');
$('#dbpw').val("");
}
});
}
$(function () {
//聚焦时默认提示
var focus_tips = {
dbhost: '数据库服务器地址,一般为localhost',
dbport: '数据库服务器端口,一般为3306',
dbuser: '',
dbpw: '',
dbname: '',
dbprefix: '建议使用默认,同一数据库安装多个bronet时需修改',
dbcharset: '如果您的服务器是虚拟空间不支持uft8mb4,请选择 utf8',
manager: '创始人帐号,拥有站点后台所有管理权限',
manager_pwd: '',
manager_ckpwd: '',
sitename: '',
siteurl: '请以“/”结尾',
sitekeywords: '',
siteinfo: '',
manager_email: ''
};
var install_form = $("#js-install-form");
//validate插件修改了remote ajax验证返回的response处理方式;增加密码强度提示 passwordRank
install_form.validate({
//debug : true,
//onsubmit : false,
errorPlacement: function (error, element) {
//错误提示容器
$('#js-install-tip-' + element[0].name).html(error);
},
errorElement: 'span',
//invalidHandler : , 未验证通过 回调
//ignore : '.ignore' 忽略验证
//onkeyup : true,
errorClass: 'tips-error',
validClass: 'tips-error',
onkeyup: false,
focusInvalid: false,
rules: {
dbhost: {required: true},
dbport: {required: true},
dbuser: {required: true},
/* dbpw: {required : true}, */
dbname: {required: true},
dbprefix: {required: true},
manager: {required: true},
manager_pwd: {required: true},
manager_ckpwd: {required: true, equalTo: '#js-manager-pwd'},
manager_email: {required: true, email: true}
},
highlight: false,
unhighlight: function (element, errorClass, validClass) {
var tip_elem = $('#js-install-tip-' + element.name);
tip_elem.html('<span class="' + validClass + '" data-text="text"><span>');
},
onfocusin: function (element) {
var name = element.name;
$('#js-install-tip-' + name).html('<span data-text="text">' + focus_tips[name] + '</span>');
$(element).parents('tr').addClass('current');
},
onfocusout: function (element) {
var _this = this;
$(element).parents('tr').removeClass('current');
if (element.name === 'email') {
//邮箱匹配点击后,延时处理
setTimeout(function () {
_this.element(element);
}, 150);
} else {
_this.element(element);
}
},
messages: {
dbhost: {required: '数据库服务器地址不能为空'},
dbport: {required: '数据库服务器端口不能为空'},
dbuser: {required: '数据库用户名不能为空'},
dbpw: {required: '数据库密码不能为空'},
dbname: {required: '数据库名不能为空'},
dbprefix: {required: '数据库表前缀不能为空'},
manager: {required: '管理员帐号不能为空'},
manager_pwd: {required: '密码不能为空'},
manager_ckpwd: {required: '重复密码不能为空', equalTo: '两次输入的密码不一致,请重新输入.'},
manager_email: {required: 'Email不能为空', email: '请输入正确的电子邮箱地址'}
},
submitHandler: function (form) {
form.submit();
return true;
}
});
});
</script>
</div>
<include file="public/footer"/>
</body>
</html>
\ No newline at end of file
<!doctype html>
<html>
<head>
<include file="public/head"/>
<script type="text/javascript">
//全局变量
var GV = {
ROOT: "{:cmf_get_root()}/",
WEB_ROOT: "{:cmf_get_root()}/",
JS_ROOT: "static/js/"
};
</script>
<script src="__STATIC__/js/jquery.js"></script>
<script src="__STATIC__/js/wind.js"></script>
<script type="text/html" id="exec-success-msg-tpl">
<li>
<i class="fa fa-check correct"></i>
{message}<br>
<!--<pre>{sql}</pre>-->
</li>
</script>
<script type="text/html" id="exec-fail-msg-tpl">
<li>
<i class="fa fa-remove error"></i>
{message}<br>
<pre>{sql}</pre>
<!--<pre>{exception}</pre>-->
</li>
</script>
</head>
<body>
<div class="wrap">
<include file="public/header"/>
<section class="section">
<div class="step">
<ul class="unstyled">
<li class="on"><em>1</em>检测环境</li>
<li class="on"><em>2</em>创建数据</li>
<li class="current"><em>3</em>完成安装</li>
</ul>
</div>
<div class="install" id="log">
<ul id="install-msg-panel" class="unstyled"></ul>
</div>
<div class="bottom text-center">
<a href="javascript:;"><i class="fa fa-refresh fa-spin"></i>&nbsp;正在安装...</a>
</div>
</section>
<script type="text/javascript">
$(function () {
install(0);
});
Wind.use("noty", function () {
});
var $installMsgPanel = $('#install-msg-panel');
var $log = $("#log");
var execSuccessTpl = $('#exec-success-msg-tpl').html();
var execFailTpl = $('#exec-fail-msg-tpl').html();
var sqlExecResult;
function install(sqlIndex) {
$.ajax({
url: "{:url('install/index/install')}",
data: {sql_index: sqlIndex},
dataType: 'json',
type: 'post',
success: function (data) {
console.log(data);
var line = sqlIndex + 1;
if (data.code == 1) {
if (!(data.data && data.data.done)) {
var tpl = execSuccessTpl;
tpl = tpl.replace(/\{message\}/g, line + '.' + data.msg);
tpl = tpl.replace(/\{sql\}/g, data.data.sql);
$installMsgPanel.append(tpl);
} else {
$installMsgPanel.append('<li><i class="fa fa-check correct"></i>数据库安装完成!</li>');
sqlExecResult = data.data;
if (data.data.error) {
noty({
text: "安装过程,共" + data.data.error + "个SQL执行错误,可能您在此数据库下已经安装过 CMF,请查看问题后重新安装,或者<br>"
+ '<a target="_blank" href="https://github.com/bronet/bronet/issues">反馈问题</a>',
type: 'confirm',
layout: "center",
timeout: false,
modal: true,
buttons: [
{
addClass: 'btn btn-primary',
text: '确定',
onClick: function ($noty) {
$noty.close();
//setDbConfig();
}
},
{
addClass: 'btn btn-danger',
text: '取消',
onClick: function ($noty) {
$noty.close();
}
}
]
});
} else {
setDbConfig();
}
}
} else if (data.code == 0) {
var tpl = execFailTpl;
tpl = tpl.replace(/\{message\}/g, line + '.' + data.msg);
tpl = tpl.replace(/\{sql\}/g, data.data.sql);
tpl = tpl.replace(/\{exception\}/g, data.data.exception);
$installMsgPanel.append(tpl);
}
$log.scrollTop(1000000000);
if (!(data.data && data.data.done)) {
sqlIndex++;
install(sqlIndex);
}
},
error: function () {
},
complete: function () {
}
});
}
function setDbConfig() {
$.ajax({
url: "{:url('install/index/setDbConfig')}",
dataType: 'json',
data:{_hibronet:1},
type: 'post',
success: function (data) {
if (data.code == 1) {
$installMsgPanel.append('<li><i class="fa fa-check correct"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
setSite();
} else {
$installMsgPanel.append('<li><i class="fa fa-remove error"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
noty({
text: data.msg + ',请检查 data/conf/database.php 是否可写!',
type: 'confirm',
layout: "center",
timeout: false,
modal: true,
buttons: [
{
addClass: 'btn btn-primary',
text: '重试',
onClick: function ($noty) {
$noty.close();
setDbConfig();
}
},
{
addClass: 'btn btn-danger',
text: '取消',
onClick: function ($noty) {
$noty.close();
}
}
]
});
}
},
error: function () {
}
});
}
function setSite() {
$.ajax({
url: "{:url('install/index/setSite')}",
dataType: 'json',
data:{_hibronet:1},
type: 'post',
success: function (data) {
if (data.code == 1) {
$installMsgPanel.append('<li><i class="fa fa-check correct"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
installTheme();
} else {
$installMsgPanel.append('<li><i class="fa fa-remove error"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
noty({
text: data.msg,
type: 'confirm',
layout: "center",
timeout: false,
modal: true,
buttons: [
{
addClass: 'btn btn-primary',
text: '重试',
onClick: function ($noty) {
$noty.close();
setSite();
}
},
{
addClass: 'btn btn-danger',
text: '取消',
onClick: function ($noty) {
$noty.close();
}
}
]
});
}
},
error: function () {
}
});
}
function installTheme() {
$.ajax({
url: "{:url('install/index/installTheme')}",
dataType: 'json',
data:{_hibronet:1},
type: 'post',
success: function (data) {
if (data.code == 1) {
$installMsgPanel.append('<li><i class="fa fa-check correct"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
setTimeout(function () {
window.location = "{:url('install/index/step5')}";
}, 1000);
} else {
$installMsgPanel.append('<li><i class="fa fa-remove error"></i>' + data.msg + '</li>');
$log.scrollTop(1000000000);
noty({
text: data.msg,
type: 'confirm',
layout: "center",
timeout: false,
modal: true,
buttons: [
{
addClass: 'btn btn-primary',
text: '重试',
onClick: function ($noty) {
$noty.close();
installTheme();
}
},
{
addClass: 'btn btn-danger',
text: '取消',
onClick: function ($noty) {
$noty.close();
}
}
]
});
}
},
error: function () {
}
});
}
</script>
</div>
<include file="public/footer"/>
</body>
</html>
\ No newline at end of file
<!doctype html>
<html>
<head>
<include file="public/head" />
<script src="__STATIC__/js/jquery.js"></script>
</head>
<body>
<div class="wrap">
<include file="public/header" />
<section class="section">
<div style="padding: 40px 20px;">
<div class="text-center">
<a style="font-size: 18px;">恭喜您,安装完成!</a>
<br>
<br>
<div class="alert alert-danger" style="width: 350px;display: inline-block;">
为了您站点的安全,安装完成后即可将网站app目录下的“install”文件夹删除!
另请对data/conf/database.php文件做好备份,以防丢失!
</div>
<br>
<a class="btn btn-success" href="{:cmf_get_root()}/">进入前台</a>
<a class="btn btn-success" href="{:cmf_get_root()}/index.php?s=admin">进入后台</a>
</div>
</div>
</section>
</div>
<include file="public/footer" />
<script>
$(function() {
return;
$.ajax({
type : "POST",
url : "http://www.bronet.cn/service/installinfo.php",
data : {
host : "{$host|default=''}",
ip : "{$ip|default=''}"
},
dataType : 'json',
success : function() {
}
});
});
</script>
</body>
</html>
\ No newline at end of file
... ... @@ -97,6 +97,7 @@ class IndexController extends HomeBaseController
protected function wechatUserRegister($wechat_user,$openid,$appId){
$currentTime = time();
$ip = $this->request->ip(0, true);
$number = $this->number();
Db::startTrans();
$userId = Db::name("user")->insertGetId([
'create_time' => $currentTime,
... ... @@ -107,6 +108,7 @@ class IndexController extends HomeBaseController
'avatar' => $wechat_user['avatar'],
'last_login_ip' => $ip,
'last_login_time' => $currentTime,
'number' => $number,
]);
$row=Db::name("third_party_user")->insert([
... ...
<?php return array (
);
\ No newline at end of file
... ...
<?php
return array (
'ADMIN_HOOK_INDEX' => '钩子管理',
'ADMIN_HOOK_PLUGINLISTORDER' => '钩子插件排序',
'ADMIN_HOOK_PLUGINS' => '钩子插件管理',
'ADMIN_HOOK_SYNC' => '同步钩子',
'ADMIN_INSURANCECOMPANY_INDEX' => '保险公司列表',
'ADMIN_INSURANCETYPE_INDEX' => '保险类型列表',
'ADMIN_LINK_ADD' => '添加友情链接',
'ADMIN_LINK_ADDPOST' => '添加友情链接提交保存',
'ADMIN_LINK_DELETE' => '删除友情链接',
'ADMIN_LINK_EDIT' => '编辑友情链接',
'ADMIN_LINK_EDITPOST' => '编辑友情链接提交保存',
'ADMIN_LINK_INDEX' => '友情链接',
'ADMIN_LINK_LISTORDER' => '友情链接排序',
'ADMIN_LINK_TOGGLE' => '友情链接显示隐藏',
'ADMIN_MAILER_INDEX' => '邮箱配置',
'ADMIN_MAILER_INDEXPOST' => '邮箱配置提交保存',
'ADMIN_MAILER_TEMPLATE' => '邮件模板',
'ADMIN_MAILER_TEMPLATEPOST' => '邮件模板提交',
'ADMIN_MAILER_TEST' => '邮件发送测试',
'ADMIN_MENU_ADD' => '后台菜单添加',
'ADMIN_MENU_ADDPOST' => '后台菜单添加提交保存',
'ADMIN_MENU_DELETE' => '后台菜单删除',
'ADMIN_MENU_EDIT' => '后台菜单编辑',
'ADMIN_MENU_EDITPOST' => '后台菜单编辑提交保存',
'ADMIN_MENU_GETACTIONS' => '导入新后台菜单',
'ADMIN_MENU_INDEX' => '后台菜单',
'ADMIN_MENU_LISTORDER' => '后台菜单排序',
'ADMIN_MENU_LISTS' => '所有菜单',
'ADMIN_NAV_ADD' => '添加导航',
'ADMIN_NAV_ADDPOST' => '添加导航提交保存',
'ADMIN_NAV_DELETE' => '删除导航',
'ADMIN_NAV_EDIT' => '编辑导航',
'ADMIN_NAV_EDITPOST' => '编辑导航提交保存',
'ADMIN_NAV_INDEX' => '导航管理',
'ADMIN_NAVMENU_ADD' => '添加导航菜单',
'ADMIN_NAVMENU_ADDPOST' => '添加导航菜单提交保存',
'ADMIN_NAVMENU_DELETE' => '删除导航菜单',
'ADMIN_NAVMENU_EDIT' => '编辑导航菜单',
'ADMIN_NAVMENU_EDITPOST' => '编辑导航菜单提交保存',
'ADMIN_NAVMENU_INDEX' => '导航菜单',
'ADMIN_NAVMENU_LISTORDER' => '导航菜单排序',
'ADMIN_PAYMETHOD_INDEX' => '缴费方式列表',
'ADMIN_PLUGIN_DEFAULT' => '插件管理',
'ADMIN_PLUGIN_INDEX' => '插件列表',
'ADMIN_PLUGIN_INSTALL' => '插件安装',
'ADMIN_PLUGIN_SETTING' => '插件设置',
'ADMIN_PLUGIN_SETTINGPOST' => '插件设置提交',
'ADMIN_PLUGIN_TOGGLE' => '插件启用禁用',
'ADMIN_PLUGIN_UNINSTALL' => '卸载插件',
'ADMIN_PLUGIN_UPDATE' => '插件更新',
'ADMIN_RBAC_AUTHORIZE' => '设置角色权限',
'ADMIN_RBAC_AUTHORIZEPOST' => '角色授权提交',
'ADMIN_RBAC_INDEX' => '角色管理',
'ADMIN_RBAC_ROLEADD' => '添加角色',
'ADMIN_RBAC_ROLEADDPOST' => '添加角色提交',
'ADMIN_RBAC_ROLEDELETE' => '删除角色',
'ADMIN_RBAC_ROLEEDIT' => '编辑角色',
'ADMIN_RBAC_ROLEEDITPOST' => '编辑角色提交',
'ADMIN_RECYCLEBIN_DELETE' => '回收站彻底删除',
'ADMIN_RECYCLEBIN_INDEX' => '回收站',
'ADMIN_RECYCLEBIN_RESTORE' => '回收站还原',
'ADMIN_ROUTE_ADD' => '添加路由规则',
'ADMIN_ROUTE_ADDPOST' => '添加路由规则提交',
'ADMIN_ROUTE_BAN' => '路由规则禁用',
'ADMIN_ROUTE_DELETE' => '路由规则删除',
'ADMIN_ROUTE_EDIT' => '路由规则编辑',
'ADMIN_ROUTE_EDITPOST' => '路由规则编辑提交',
'ADMIN_ROUTE_INDEX' => 'URL美化',
'ADMIN_ROUTE_LISTORDER' => '路由规则排序',
'ADMIN_ROUTE_OPEN' => '路由规则启用',
'ADMIN_ROUTE_SELECT' => '选择URL',
'ADMIN_SETTING_CLEARCACHE' => '清除缓存',
'ADMIN_SETTING_DEFAULT' => '设置',
'ADMIN_SETTING_PASSWORD' => '密码修改',
'ADMIN_SETTING_PASSWORDPOST' => '密码修改提交',
'ADMIN_SETTING_SITE' => '网站信息',
'ADMIN_SETTING_SITEPOST' => '网站信息设置提交',
'ADMIN_SETTING_UPLOAD' => '上传设置',
'ADMIN_SETTING_UPLOADPOST' => '上传设置提交',
'ADMIN_SLIDE_ADD' => '添加幻灯片',
'ADMIN_SLIDE_ADDPOST' => '添加幻灯片提交',
'ADMIN_SLIDE_DELETE' => '删除幻灯片',
'ADMIN_SLIDE_EDIT' => '编辑幻灯片',
'ADMIN_SLIDE_EDITPOST' => '编辑幻灯片提交',
'ADMIN_SLIDE_INDEX' => '幻灯片管理',
'ADMIN_SLIDEITEM_ADD' => '幻灯片页面添加',
'ADMIN_SLIDEITEM_ADDPOST' => '幻灯片页面添加提交',
'ADMIN_SLIDEITEM_BAN' => '幻灯片页面隐藏',
'ADMIN_SLIDEITEM_CANCELBAN' => '幻灯片页面显示',
'ADMIN_SLIDEITEM_DELETE' => '幻灯片页面删除',
'ADMIN_SLIDEITEM_EDIT' => '幻灯片页面编辑',
'ADMIN_SLIDEITEM_EDITPOST' => '幻灯片页面编辑提交',
'ADMIN_SLIDEITEM_INDEX' => '幻灯片页面列表',
'ADMIN_SLIDEITEM_LISTORDER' => '幻灯片页面排序',
'ADMIN_STORAGE_INDEX' => '文件存储',
'ADMIN_STORAGE_SETTINGPOST' => '文件存储设置提交',
'ADMIN_THEME_ACTIVE' => '启用模板',
'ADMIN_THEME_DATASOURCE' => '模板文件设置数据源',
'ADMIN_THEME_FILEARRAYDATA' => '模板文件数组数据列表',
'ADMIN_THEME_FILEARRAYDATADELETE' => '模板文件数组数据删除',
'ADMIN_THEME_FILEARRAYDATAEDIT' => '模板文件数组数据添加编辑',
'ADMIN_THEME_FILEARRAYDATAEDITPOST' => '模板文件数组数据添加编辑提交保存',
'ADMIN_THEME_FILES' => '模板文件列表',
'ADMIN_THEME_FILESETTING' => '模板文件设置',
'ADMIN_THEME_INDEX' => '模板管理',
'ADMIN_THEME_INSTALL' => '安装模板',
'ADMIN_THEME_INSTALLTHEME' => '模板安装',
'ADMIN_THEME_SETTINGPOST' => '模板文件编辑提交保存',
'ADMIN_THEME_UNINSTALL' => '卸载模板',
'ADMIN_THEME_UPDATE' => '模板更新',
'ADMIN_USER_ADD' => '管理员添加',
'ADMIN_USER_ADDPOST' => '管理员添加提交',
'ADMIN_USER_BAN' => '停用管理员',
'ADMIN_USER_CANCELBAN' => '启用管理员',
'ADMIN_USER_DEFAULT' => '管理组',
'ADMIN_USER_DELETE' => '管理员删除',
'ADMIN_USER_EDIT' => '管理员编辑',
'ADMIN_USER_EDITPOST' => '管理员编辑提交',
'ADMIN_USER_INDEX' => '管理员',
'ADMIN_USER_USERINFO' => '个人信息',
'ADMIN_USER_USERINFOPOST' => '管理员个人信息修改提交',
'ADMIN_选项管理_INDEX' => '选项管理',
'PORTAL_ADMINARTICLE_ADD' => '添加文章',
'PORTAL_ADMINARTICLE_ADDPOST' => '添加文章提交',
'PORTAL_ADMINARTICLE_DELETE' => '文章删除',
'PORTAL_ADMINARTICLE_EDIT' => '编辑文章',
'PORTAL_ADMINARTICLE_EDITPOST' => '编辑文章提交',
'PORTAL_ADMINARTICLE_INDEX' => '文章管理',
'PORTAL_ADMINARTICLE_LISTORDER' => '文章排序',
'PORTAL_ADMINARTICLE_PUBLISH' => '文章发布',
'PORTAL_ADMINARTICLE_RECOMMEND' => '文章推荐',
'PORTAL_ADMINARTICLE_TOP' => '文章置顶',
'PORTAL_ADMINCATEGORY_ADD' => '添加文章分类',
'PORTAL_ADMINCATEGORY_ADDPOST' => '添加文章分类提交',
'PORTAL_ADMINCATEGORY_DELETE' => '删除文章分类',
'PORTAL_ADMINCATEGORY_EDIT' => '编辑文章分类',
'PORTAL_ADMINCATEGORY_EDITPOST' => '编辑文章分类提交',
'PORTAL_ADMINCATEGORY_INDEX' => '分类管理',
'PORTAL_ADMINCATEGORY_LISTORDER' => '文章分类排序',
'PORTAL_ADMINCATEGORY_SELECT' => '文章分类选择对话框',
'PORTAL_ADMININDEX_DEFAULT' => '门户管理',
'PORTAL_ADMINPAGE_ADD' => '添加页面',
'PORTAL_ADMINPAGE_ADDPOST' => '添加页面提交',
'PORTAL_ADMINPAGE_DELETE' => '删除页面',
'PORTAL_ADMINPAGE_EDIT' => '编辑页面',
'PORTAL_ADMINPAGE_EDITPOST' => '编辑页面提交',
'PORTAL_ADMINPAGE_INDEX' => '页面管理',
'PORTAL_ADMINTAG_ADD' => '添加文章标签',
'PORTAL_ADMINTAG_ADDPOST' => '添加文章标签提交',
'PORTAL_ADMINTAG_DELETE' => '删除文章标签',
'PORTAL_ADMINTAG_INDEX' => '文章标签',
'PORTAL_ADMINTAG_UPSTATUS' => '更新标签状态',
'USER_ADMINASSET_DELETE' => '删除文件',
'USER_ADMINASSET_INDEX' => '资源管理',
'USER_ADMININDEX_BAN' => '本站用户拉黑',
'USER_ADMININDEX_CANCELBAN' => '本站用户启用',
'USER_ADMININDEX_DEFAULT' => '用户管理',
'USER_ADMININDEX_DEFAULT1' => '用户组',
'USER_ADMININDEX_INDEX' => '本站用户',
'USER_ADMINOAUTH_DELETE' => '删除第三方用户绑定',
'USER_ADMINOAUTH_INDEX' => '第三方用户',
'USER_ADMINUSERACTION_EDIT' => '编辑用户操作',
'USER_ADMINUSERACTION_EDITPOST' => '编辑用户操作提交',
'USER_ADMINUSERACTION_INDEX' => '用户操作管理',
'USER_ADMINUSERACTION_SYNC' => '同步用户操作',
);
\ No newline at end of file
... ...
VXjedLb2uAcqtBPC
\ No newline at end of file
o9riaAc321VhxBtr
\ No newline at end of file
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('InsuranceCompany/index')}">保险公司列表</a></li>
<li class="active"><a href="{:url('InsuranceCompany/add')}">添加保险公司</a></li>
</ul>
<form action="{:url('InsuranceCompany/add')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">保险公司<span class="form-required">*</span></th>
<td>
<input class="form-control" type="text" name="insurance_company_name"
id="" value="" placeholder="请输入保险公司..."/>
</td>
</tr>
<tr>
<th width="100">缩略图<span class="form-required">*</span></th>
<td>
<div style="text-align: center;">
<input type="hidden" name="thumbnail" id="thumbnail" value="">
<a href="javascript:uploadOneImage('图片上传','#thumbnail');">
<img src="__TMPL__/public/assets/images/default-thumbnail.png"
id="thumbnail-preview"
width="135" style="cursor: pointer"/>
</a>
<input type="button" class="btn btn-sm btn-cancel-thumbnail" value="取消图片">
</div>
</td>
</tr>
</table>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('ADD')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
});
</script>
</body>
</html>
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('InsuranceCompany/index')}">保险公司列表</a></li>
<li>
<a href="{:url('InsuranceCompany/add')}">添加保险公司</a>
</li>
<li class="active"><a href="#">编辑保险公司</a></li>
</ul>
<form action="{:url('InsuranceCompany/edit')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">保险公司<span class="form-required">*</span></th>
<td>
<input type="text" class="form-control" name="insurance_company_name" value="{$data.insurance_company_name}" placeholder="请输入保险公司..."/>
</td>
<input type="hidden" name="id" value="{$data.id}"/>
</tr>
<tr>
<th width="100">缩略图<span class="form-required">*</span></th>
<td>
<div style="text-align: center;">
<input type="hidden" name="thumbnail" id="thumbnail"
value="{$data.thumbnail|default=''}">
<a href="javascript:uploadOneImage('图片上传','#thumbnail');">
<if condition="empty($data.thumbnail)">
<img src="__TMPL__/public/assets/images/default-thumbnail.png"
id="thumbnail-preview"
width="135" style="cursor: pointer"/>
<else/>
<img src="{:cmf_get_image_preview_url($data.thumbnail)}"
id="thumbnail-preview"
width="135" style="cursor: pointer"/>
</if>
</a>
<input type="button" class="btn btn-sm btn-cancel-thumbnail" value="取消图片">
</div>
</td>
</tr>
</table>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('SAVE')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
$('#more-template-select').val("{$post.more.template|default=''}");
//判断是否为推荐
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}
$('#aaa').click(function(){
// alert($('#recommended_yes').is(":checked"))
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}else{
$('#title').hide()
}
})
});
function doSelectCategory() {
var selectedCategoriesId = $('#js-categories-id-input').val();
openIframeLayer("{:url('AdminCategory/select')}?ids=" + selectedCategoriesId, '请选择分类', {
area: ['700px', '400px'],
btn: ['确定', '取消'],
yes: function (index, layero) {
//do something
var iframeWin = window[layero.find('iframe')[0]['name']];
var selectedCategories = iframeWin.confirm();
if (selectedCategories.selectedCategoriesId.length == 0) {
layer.msg('请选择分类');
return;
}
$('#js-categories-id-input').val(selectedCategories.selectedCategoriesId.join(','));
$('#js-categories-name-input').val(selectedCategories.selectedCategoriesName.join(' '));
//console.log(layer.getFrameIndex(index));
layer.close(index); //如果设定了yes回调,需进行手工关闭
}
});
}
</script>
</body>
</html>
\ No newline at end of file
... ...
<include file="public@header" />
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li class="active"><a href="{:url('InsuranceCompany/index')}">保险公司列表</a></li>
<li><a href="{:url('InsuranceCompany/add')}">添加保险公司</a></li>
</ul>
<form class="well form-inline margin-top-20" method="post" action="{:url('InsuranceCompany/index')}">
保险公司:
<input type="text" class="form-control" name="keyword" style="width: 150px;" value="{$keyword|default=''}" placeholder="请输入保险公司...">
<input type="submit" class="btn btn-primary" value="搜索" />
<a class="btn btn-danger" href="{:url('InsuranceCompany/index')}">清空</a>
</form>
<form class="js-ajax-form" action="" method="post">
<table class="table table-hover table-bordered">
<div class="table-actions">
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceCompany/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<thead>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="20">ID</th>
<th width="20">缩略图</th>
<th width="50">保险公司</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</thead>
<tbody>
<foreach name="data" item="vo">
<tr>
<td>
<input type="checkbox" class="js-check" data-yid="js-check-y" data-xid="js-check-x" name="ids[]"
value="{$vo.id}" title="ID:{$vo.id}">
</td>
<td>{$vo.id}</td>
<td>
<notempty name="vo.thumbnail">
<a href="javascript:parent.imagePreviewDialog('{:cmf_get_image_preview_url($vo.thumbnail)}');">
<i class="fa fa-photo fa-fw"></i>
</a>
</notempty>
</td>
<td>{$vo.insurance_company_name}</td>
<td>{:date('Y-m-d H:i:s',$vo['create_time'])}</td>
<td>{:date('Y-m-d H:i:s',$vo['update_time'])}</td>
<td>
<a href='{:url("InsuranceCompany/edit",array("id"=>$vo["id"]))}'>编辑</a>|
<a class="js-ajax-delete" href="{:url('InsuranceCompany/delete',array('id'=>$vo['id']))}">{:lang('DELETE')}</a>
</td>
</tr>
</foreach>
</tbody>
<tfoot>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="20">ID</th>
<th width="20">缩略图</th>
<th width="50">保险公司</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</tfoot>
</table>
<div class="table-actions">
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceCompany/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<div class="pagination">{$page}</div>
</form>
</div>
<script src="__STATIC__/js/admin.js"></script>
</body>
</html>
\ No newline at end of file
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('InsuranceType/index')}">保险类型列表</a></li>
<li class="active"><a href="{:url('InsuranceType/add')}">添加保险类型</a></li>
</ul>
<form action="{:url('InsuranceType/add')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">保险类型<span class="form-required">*</span></th>
<td>
<input class="form-control" type="text" name="insurance_type_name"
id="" value="" placeholder="请输入保险类型..."/>
</td>
</tr>
</table>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('ADD')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
});
</script>
</body>
</html>
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('InsuranceType/index')}">保险类型列表</a></li>
<li>
<a href="{:url('InsuranceType/add')}">添加保险类型</a>
</li>
<li class="active"><a href="#">编辑保险类型</a></li>
</ul>
<form action="{:url('InsuranceType/edit')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">保险类型<span class="form-required">*</span></th>
<td>
<input type="text" class="form-control" name="insurance_type_name" value="{$data.insurance_type_name}" placeholder="请输入保险公司..."/>
</td>
<input type="hidden" name="id" value="{$data.id}"/>
</tr>
</table>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('SAVE')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
$('#more-template-select').val("{$post.more.template|default=''}");
//判断是否为推荐
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}
$('#aaa').click(function(){
// alert($('#recommended_yes').is(":checked"))
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}else{
$('#title').hide()
}
})
});
function doSelectCategory() {
var selectedCategoriesId = $('#js-categories-id-input').val();
openIframeLayer("{:url('AdminCategory/select')}?ids=" + selectedCategoriesId, '请选择分类', {
area: ['700px', '400px'],
btn: ['确定', '取消'],
yes: function (index, layero) {
//do something
var iframeWin = window[layero.find('iframe')[0]['name']];
var selectedCategories = iframeWin.confirm();
if (selectedCategories.selectedCategoriesId.length == 0) {
layer.msg('请选择分类');
return;
}
$('#js-categories-id-input').val(selectedCategories.selectedCategoriesId.join(','));
$('#js-categories-name-input').val(selectedCategories.selectedCategoriesName.join(' '));
//console.log(layer.getFrameIndex(index));
layer.close(index); //如果设定了yes回调,需进行手工关闭
}
});
}
</script>
</body>
</html>
\ No newline at end of file
... ...
<include file="public@header" />
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li class="active"><a href="{:url('InsuranceType/index')}">保险类型列表</a></li>
<li><a href="{:url('InsuranceType/add')}">添加保险类型</a></li>
</ul>
<form class="well form-inline margin-top-20" method="post" action="{:url('InsuranceType/index')}">
保险类型:
<input type="text" class="form-control" name="keyword" style="width: 150px;" value="{$keyword|default=''}" placeholder="请输入保险类型...">
<input type="submit" class="btn btn-primary" value="搜索" />
<a class="btn btn-danger" href="{:url('InsuranceType/index')}">清空</a>
</form>
<form class="js-ajax-form" action="" method="post">
<table class="table table-hover table-bordered">
<div class="table-actions">
<button class="btn btn-primary btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceType/listOrder')}">{:lang('SORT')}
</button>
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceType/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<thead>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="15">排序</th>
<th width="20">ID</th>
<th width="50">保险类型</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</thead>
<tbody>
<foreach name="data" item="vo">
<tr>
<td>
<input type="checkbox" class="js-check" data-yid="js-check-y" data-xid="js-check-x" name="ids[]"
value="{$vo.id}" title="ID:{$vo.id}">
</td>
<td>
<input name="list_orders[{$vo.id}]" class="input-order" type="text"
value="{$vo.list_order}">
</td>
<td>{$vo.id}</td>
<td>{$vo.insurance_type_name}</td>
<td>{:date('Y-m-d H:i:s',$vo['create_time'])}</td>
<td>{:date('Y-m-d H:i:s',$vo['update_time'])}</td>
<td>
<a href='{:url("InsuranceType/edit",array("id"=>$vo["id"]))}'>编辑</a>|
<a class="js-ajax-delete" href="{:url('InsuranceType/delete',array('id'=>$vo['id']))}">{:lang('DELETE')}</a>
</td>
</tr>
</foreach>
</tbody>
<tfoot>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="15">排序</th>
<th width="20">ID</th>
<th width="50">保险类型</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</tfoot>
</table>
<div class="table-actions">
<button class="btn btn-primary btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceType/listOrder')}">{:lang('SORT')}
</button>
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('InsuranceCompany/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<div class="pagination">{$page}</div>
</form>
</div>
<script src="__STATIC__/js/admin.js"></script>
</body>
</html>
\ No newline at end of file
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('PayMethod/index')}">缴费方式列表</a></li>
<li class="active"><a href="{:url('PayMethod/add')}">缴费方式类型</a></li>
</ul>
<form action="{:url('PayMethod/add')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">缴费方式<span class="form-required">*</span></th>
<td>
<input class="form-control" type="text" name="pay_method_name"
id="" value="" placeholder="请输入缴费方式..."/>
</td>
</tr>
</table>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('ADD')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
});
</script>
</body>
</html>
... ...
<include file="public@header"/>
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li><a href="{:url('PayMethod/index')}">缴费方式列表</a></li>
<li>
<a href="{:url('PayMethod/add')}">添加缴费方式</a>
</li>
<li class="active"><a href="#">编辑缴费方式</a></li>
</ul>
<form action="{:url('PayMethod/edit')}" method="post" class="form-horizontal js-ajax-form margin-top-20">
<div class="row">
<div class="col-md-9">
<table class="table table-bordered">
<tr>
<th width="100">缴费方式<span class="form-required">*</span></th>
<td>
<input type="text" class="form-control" name="pay_method_name" value="{$data.pay_method_name}" placeholder="请输入缴费方式..."/>
</td>
<input type="hidden" name="id" value="{$data.id}"/>
</tr>
</table>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary js-ajax-submit">{:lang('SAVE')}</button>
<a class="btn btn-default" href="javascript:history.back(-1);">{:lang('BACK')}</a>
</div>
</div>
</form>
</div>
<script type="text/javascript" src="__STATIC__/js/admin.js"></script>
<script type="text/javascript">
//编辑器路径定义
var editorURL = GV.WEB_ROOT;
</script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.config.js"></script>
<script type="text/javascript" src="__STATIC__/js/ueditor/ueditor.all.min.js"></script>
<script type="text/javascript">
$(function () {
editorcontent = new baidu.editor.ui.Editor();
editorcontent.render('content');
try {
editorcontent.sync();
} catch (err) {
}
$('.btn-cancel-thumbnail').click(function () {
$('#thumbnail-preview').attr('src', '__TMPL__/public/assets/images/default-thumbnail.png');
$('#thumbnail').val('');
});
$('#more-template-select').val("{$post.more.template|default=''}");
//判断是否为推荐
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}
$('#aaa').click(function(){
// alert($('#recommended_yes').is(":checked"))
if($('#recommended_yes').is(":checked")==true){
$('#title').show()
}else{
$('#title').hide()
}
})
});
function doSelectCategory() {
var selectedCategoriesId = $('#js-categories-id-input').val();
openIframeLayer("{:url('AdminCategory/select')}?ids=" + selectedCategoriesId, '请选择分类', {
area: ['700px', '400px'],
btn: ['确定', '取消'],
yes: function (index, layero) {
//do something
var iframeWin = window[layero.find('iframe')[0]['name']];
var selectedCategories = iframeWin.confirm();
if (selectedCategories.selectedCategoriesId.length == 0) {
layer.msg('请选择分类');
return;
}
$('#js-categories-id-input').val(selectedCategories.selectedCategoriesId.join(','));
$('#js-categories-name-input').val(selectedCategories.selectedCategoriesName.join(' '));
//console.log(layer.getFrameIndex(index));
layer.close(index); //如果设定了yes回调,需进行手工关闭
}
});
}
</script>
</body>
</html>
\ No newline at end of file
... ...
<include file="public@header" />
</head>
<body>
<div class="wrap js-check-wrap">
<ul class="nav nav-tabs">
<li class="active"><a href="{:url('PayMethod/index')}">缴费方式列表</a></li>
<li><a href="{:url('PayMethod/add')}">添加缴费方式</a></li>
</ul>
<form class="well form-inline margin-top-20" method="post" action="{:url('PayMethod/index')}">
缴费方式:
<input type="text" class="form-control" name="keyword" style="width: 150px;" value="{$keyword|default=''}" placeholder="请输入缴费方式...">
<input type="submit" class="btn btn-primary" value="搜索" />
<a class="btn btn-danger" href="{:url('PayMethod/index')}">清空</a>
</form>
<form class="js-ajax-form" action="" method="post">
<table class="table table-hover table-bordered">
<div class="table-actions">
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('PayMethod/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<thead>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="20">ID</th>
<th width="50">缴费方式</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</thead>
<tbody>
<foreach name="data" item="vo">
<tr>
<td>
<input type="checkbox" class="js-check" data-yid="js-check-y" data-xid="js-check-x" name="ids[]"
value="{$vo.id}" title="ID:{$vo.id}">
</td>
<td>{$vo.id}</td>
<td>{$vo.pay_method_name}</td>
<td>{:date('Y-m-d H:i:s',$vo['create_time'])}</td>
<td>{:date('Y-m-d H:i:s',$vo['update_time'])}</td>
<td>
<a href='{:url("PayMethod/edit",array("id"=>$vo["id"]))}'>编辑</a>|
<a class="js-ajax-delete" href="{:url('PayMethod/delete',array('id'=>$vo['id']))}">{:lang('DELETE')}</a>
</td>
</tr>
</foreach>
</tbody>
<tfoot>
<tr>
<th width="15">
<label>
<input type="checkbox" class="js-check-all" data-direction="x" data-checklist="js-check-x">
</label>
</th>
<th width="20">ID</th>
<th width="50">缴费方式</th>
<th width="30">创建时间</th>
<th width="30">更新时间</th>
<th width="100">操作</th>
</tr>
</tfoot>
</table>
<div class="table-actions">
<button class="btn btn-danger btn-sm js-ajax-submit" type="submit"
data-action="{:url('PayMethod/delete')}" data-subcheck="true" data-msg="您确定删除吗?">
{:lang('DELETE')}
</button>
</div>
<div class="pagination">{$page}</div>
</form>
</div>
<script src="__STATIC__/js/admin.js"></script>
</body>
</html>
\ No newline at end of file
... ...
... ... @@ -1777,8 +1777,8 @@ function send_sms($data){
//todo 短信账号密码
require_once EXTEND_PATH . 'nsms/nsms.php';
$url = "http://www.ztsms.cn/sendNSms.do";
$username = '';
$password = '';
$username = 'baodantuoguan';
$password = 'Cxz307312';
$sendAPI = new \sendAPI($url, $username, $password);
$sendAPI->data = $data;/*初始化数据包*/
$return = $sendAPI->sendSMS('GET');
... ...
... ... @@ -197,4 +197,19 @@ class HomeBaseController extends BaseController
}
}
public function number(){
$user_count = Db::name('user')->where('user_type',2)->count();
if(count(str_split($user_count))+1>99999){
return 99999;
}
$num = 5;
$zero = $num - $user_count;
$result = '';
for($i=1;$i<$zero;$i++){
$result .= "0";
}
$result = $result.($user_count+1);
return $result;
}
}
\ No newline at end of file
... ...
... ... @@ -219,5 +219,27 @@ class WeChatBaseController extends BaseController
$app->oauth->redirect()->send();
}
}
/**
* 用户是否微信打开
*/
public function isWechat(){
$result = cmf_is_wechat();
if(empty($result)){
$this->error('请在微信浏览器打开!','');
}
}
/**
* 阻止拉黑用户
*/
public function ban(){
$user_id = cmf_get_current_user_id();
if (empty($userId)) {
$this->error("用户尚未登录", url("index/index/index"));
}
$user = Db::name('user')->where('id',$user_id)->find();
if($user['user_status'] == 0){
$this->error('兄嘚,你被拉黑啦!','');
}
}
}
\ No newline at end of file
... ...