File: /www/wwwroot//mw.umchkw.com/application/admin/controller/Ajax.php
<?php
/**
* 易优CMS
* ============================================================================
* 版权所有 2016-2028 海南赞赞网络科技有限公司,并保留所有权利。
* 网站地址: http://www.eyoucms.com
* ----------------------------------------------------------------------------
* 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
* ============================================================================
* Author: 小虎哥 <1105415366@qq.com>
* Date: 2018-4-3
*/
namespace app\admin\controller;
use think\Db;
use think\Session;
use think\Config;
use app\admin\logic\AjaxLogic;
/**
* 所有ajax请求或者不经过权限验证的方法全放在这里
*/
class Ajax extends Base {
private $ajaxLogic;
public function _initialize() {
parent::_initialize();
$this->ajaxLogic = new AjaxLogic;
}
/*
* 移动重新排序
*/
public function ajax_move_admin_menu(){
$post = input("post.");
$menu_id_arr = $post['menu_id'];
try{
foreach ($menu_id_arr as $key=>$val){
if ($val != 2004){
Db::name("admin_menu")->where(['menu_id'=>$val])->setField('sort_order',$key);
}
}
}catch (\Exception $e){
die("修改失败");
}
$this->success("移动排序成功");
}
/*
* 添加、删除左侧菜单栏目
*/
public function update_admin_menu(){
if (IS_AJAX_POST) {
$post = input('post.');
if (empty($post['title']) || empty($post['controller_name']) || empty($post['action_name']) || empty($post['menu_id']) || empty($post['type'])){
$this->error('请传入正确参数');
}
$menu_info = Db::name("admin_menu")->where(['menu_id'=>$post['menu_id']])->find();
$icon = !empty($post['icon']) ? $post['icon'] : 'fa fa-minus';
if ($post['type'] == 1){ //添加目录
$is_switch = isset($post['is_switch']) ? $post['is_switch'] : 1;
if (!empty($menu_info)){
$update_data = ['icon' => $icon,'is_menu'=>1, 'is_switch' => $is_switch,'sort_order'=>100,'update_time' => getTime()];
if(!empty($post['controller_name'])){
$update_data['controller_name'] = $post['controller_name'];
}
if(!empty($post['action_name'])){
$update_data['action_name'] = $post['action_name'];
}
if(!empty($post['param'])){
$update_data['param'] = $post['param'];
}
$r = Db::name("admin_menu")->where(['menu_id'=>$menu_info['menu_id']])->update($update_data);
}else{
$menu_info = [
'menu_id' => $post['menu_id'],
'title' => $post['title'],
'controller_name' => $post['controller_name'],
'action_name' => $post['action_name'],
'param' => !empty($post['param']) ? $post['param'] : '',
'icon' => $icon,
'is_menu' => 1,
'is_switch' => $is_switch,
'add_time' => getTime(),
'update_time' => getTime()
];
Db::name("admin_menu")->where([ 'title' => $post['title'], 'controller_name' => $post['controller_name'],'action_name' => $post['action_name']])->delete();
$r = Db::name("admin_menu")->insert($menu_info);
}
if ($r !== false) {
$menu_info['url'] = url($post['controller_name']."/".$post['action_name']);
$this->success("添加成功",null,$menu_info);
}
}else{ //删除目录
if (!empty($menu_info)){
$r = Db::name("admin_menu")->where(['menu_id'=>$menu_info['menu_id']])->update(['is_menu'=>0,'sort_order'=>100,'update_time' => getTime()]);
if ($r !== false) {
$this->success("删除成功");
}
}
}
}
$this->error('请求错误');
}
/**
* 进入欢迎页面需要异步处理的业务
*/
public function welcome_handle()
{
\think\Session::pause(); // 暂停session,防止session阻塞机制
$this->ajaxLogic->welcome_handle();
}
/**
* 隐藏后台欢迎页的系统提示
*/
public function explanation_welcome()
{
\think\Session::pause(); // 暂停session,防止session阻塞机制
$type = input('param.type/d', 0);
$tpCacheKey = 'system_explanation_welcome';
if (1 < $type) {
$tpCacheKey .= '_'.$type;
}
/*多语言*/
if (is_language()) {
$langRow = \think\Db::name('language')->field('mark')->order('id asc')->select();
foreach ($langRow as $key => $val) {
tpCache('system', [$tpCacheKey=>1], $val['mark']);
}
} else { // 单语言
tpCache('system', [$tpCacheKey=>1]);
}
/*--end*/
}
/**
* 版本检测更新弹窗
*/
public function check_upgrade_version()
{
\think\Session::pause(); // 暂停session,防止session阻塞机制
$upgradeLogic = new \app\admin\logic\UpgradeLogic;
$security_patch = tpSetting('upgrade.upgrade_security_patch');
if (!empty($security_patch) && 1 == $security_patch) {
$upgradeMsg = $upgradeLogic->checkSecurityVersion(); // 安全补丁包消息
} else {
$upgradeMsg = $upgradeLogic->checkVersion(); // 升级包消息
}
// 权限控制 by 小虎哥
$admin_info = session('admin_info');
if (0 < intval($admin_info['role_id'])) {
$auth_role_info = $admin_info['auth_role_info'];
if (isset($auth_role_info['online_update']) && 1 != $auth_role_info['online_update']) {
$upgradeMsg = ['code' => 1, 'msg' => '已是最新版'];
}
}
$this->success('检测成功', null, $upgradeMsg);
}
/**
* 更新stiemap.xml地图
*/
public function update_sitemap($controller, $action)
{
if (IS_AJAX_POST) {
\think\Session::pause(); // 暂停session,防止session阻塞机制
$channeltype_row = \think\Cache::get("extra_global_channeltype");
if (empty($channeltype_row)) {
$ctlArr = \think\Db::name('channeltype')
->where('id','NOTIN', [6,8])
->column('ctl_name');
} else {
$ctlArr = array();
foreach($channeltype_row as $key => $val){
if (!in_array($val['id'], [6,8])) {
$ctlArr[] = $val['ctl_name'];
}
}
}
$systemCtl= ['Arctype'];
$ctlArr = array_merge($systemCtl, $ctlArr);
$actArr = ['add','edit'];
if (in_array($controller, $ctlArr) && in_array($action, $actArr)) {
Session::pause(); // 暂停session,防止session阻塞机制
sitemap_auto();
$this->success('更新sitemap成功!');
}
}
$this->error('更新sitemap失败!');
}
// 开启\关闭余额支付
public function BalancePayOpen()
{
if (IS_AJAX_POST) {
$open_value = input('post.open_value/d');
getUsersConfigData('pay', ['pay_balance_open' => $open_value]);
$this->success('操作成功');
}
}
/**
* 跳转到前台内容页
* @return [type] [description]
*/
public function toHomeView()
{
$aid = input('param.aid/d');
$archives = Db::name('archives')->alias('a')
->field('b.*, a.*')
->join('arctype b', 'a.typeid = b.id', 'LEFT')
->where(['a.aid'=>$aid])
->find();
if (!empty($archives)) {
if ($archives['arcrank'] >= 0) {
$url = get_arcurl($archives, false);
} else {
$url = get_arcurl($archives, true);
}
header('Location: '.$url);
exit;
} else {
abort(404);
}
}
}