470 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			470 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| namespace app\admin\controller;
 | |
| use app\admin\controller\Base;
 | |
| use think\facade\Db;
 | |
| use think\facade\View;
 | |
| use think\facade\Request;
 | |
| use app\admin\controller\Log;
 | |
| use app\admin\model\AdminSysMenu;
 | |
| use app\admin\model\AdminUserGroup;
 | |
| use app\admin\model\AdminUser;
 | |
| use app\admin\model\Banner;
 | |
| 
 | |
| 
 | |
| class Yunzeradmin extends Base
 | |
| {
 | |
| 	// 角色列表
 | |
| 	public function groupinfo()
 | |
| 	{
 | |
| 		$group = AdminUserGroup::select();
 | |
| 		View::assign([
 | |
| 			'group' => $group
 | |
| 		]);
 | |
| 		return View::fetch();
 | |
| 	}
 | |
| 
 | |
| 	// 角色添加
 | |
| 	public function groupadd()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$data['group_name'] = trim(input('post.group_name'));
 | |
| 			if (!$data['group_name']) {
 | |
| 				Log::record('添加角色', 0, '角色名称不能为空', '角色管理');
 | |
| 				return json(['code' => 1, 'msg' => '角色名称不能为空']);
 | |
| 			}
 | |
| 			$data['status'] = intval(trim(input('post.status')));
 | |
| 			$data['create_time'] = time();
 | |
| 			$menus = input('post.menu/a');
 | |
| 			if ($menus) {
 | |
| 				$data['rights'] = json_encode(array_keys($menus));
 | |
| 			}
 | |
| 			$res = AdminUserGroup::insert($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('添加角色', 0, '添加角色失败', '角色管理');
 | |
| 				return json(['code' => 1, 'msg' => '添加角色失败']);
 | |
| 			}
 | |
| 			Log::record('添加角色', 1, '', '角色管理');
 | |
| 			return json(['code' => 0, 'msg' => '添加成功']);
 | |
| 		} else {
 | |
| 			$menus = AdminSysMenu::order('type,sort desc')->where('status', '=', 1)->select();
 | |
| 			$menu = [];
 | |
| 
 | |
| 			// 先处理所有父菜单
 | |
| 			foreach ($menus as $menus_v) {
 | |
| 				if ($menus_v['parent_id'] == 0) {
 | |
| 					$menu[$menus_v['smid']] = $menus_v;
 | |
| 					$menu[$menus_v['smid']]['children'] = []; // 初始化 children 数组
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			// 再处理子菜单
 | |
| 			foreach ($menus as $menus_v) {
 | |
| 				if ($menus_v['parent_id'] != 0 && isset($menu[$menus_v['parent_id']])) {
 | |
| 					$menu[$menus_v['parent_id']]['children'][] = $menus_v;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			View::assign([
 | |
| 				'menus' => $menu
 | |
| 			]);
 | |
| 			return View::fetch();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// 角色编辑
 | |
| 	public function groupedit()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$group_id = (int) trim(input('post.group_id'));
 | |
| 			$data['group_name'] = trim(input('post.group_name'));
 | |
| 			if (!$data['group_name']) {
 | |
| 				Log::record('编辑角色', 0, '角色名称不能为空', '角色管理');
 | |
| 				return json(['code' => 1, 'msg' => '角色名称不能为空']);
 | |
| 			}
 | |
| 			$data['status'] = (int) trim(input('post.status'));
 | |
| 			$menus = input('post.menu/a');
 | |
| 			if ($menus) {
 | |
| 				$data['rights'] = json_encode(array_keys($menus));
 | |
| 			} else {
 | |
| 				$data['rights'] = '';
 | |
| 			}
 | |
| 			$res = AdminUserGroup::where('group_id', $group_id)->update($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('编辑角色', 0, '更新角色失败', '角色管理');
 | |
| 				return json(['code' => 1, 'msg' => '更新角色失败']);
 | |
| 			}
 | |
| 			Log::record('编辑角色', 1, '', '角色管理');
 | |
| 			return json(['code' => 0, 'msg' => '更新成功']);
 | |
| 		} else {
 | |
| 			$group_id = (int) input('get.group_id');
 | |
| 			$group = AdminUserGroup::where('group_id', $group_id)->find();
 | |
| 			if ($group && $group['rights']) {
 | |
| 				$group['rights'] = json_decode($group['rights']);
 | |
| 			}
 | |
| 
 | |
| 			$menus = AdminSysMenu::order('type,sort desc')->where('status', '=', 1)->select();
 | |
| 			$menu = [];
 | |
| 
 | |
| 			// 先处理所有父菜单
 | |
| 			foreach ($menus as $menus_v) {
 | |
| 				if ($menus_v['parent_id'] == 0) {
 | |
| 					$menu[$menus_v['smid']] = $menus_v;
 | |
| 					$menu[$menus_v['smid']]['children'] = []; // 初始化 children 数组
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			// 再处理子菜单
 | |
| 			foreach ($menus as $menus_v) {
 | |
| 				if ($menus_v['parent_id'] != 0 && isset($menu[$menus_v['parent_id']])) {
 | |
| 					$menu[$menus_v['parent_id']]['children'][] = $menus_v;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			View::assign([
 | |
| 				'group' => $group,
 | |
| 				'menus' => $menu
 | |
| 			]);
 | |
| 			return View::fetch();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// 角色删除
 | |
| 	public function groupdel()
 | |
| 	{
 | |
| 		$group_id = (int) input('post.group_id');
 | |
| 		$res = AdminUserGroup::where('group_id', $group_id)->delete();
 | |
| 		if (empty($res)) {
 | |
| 			Log::record('删除角色', 0, '删除角色失败', '角色管理');
 | |
| 			return json(['code' => 1, 'msg' => '删除角色失败']);
 | |
| 		}
 | |
| 		Log::record('删除角色', 1, '', '角色管理');
 | |
| 		return json(['code' => 0, 'msg' => '删除成功']);
 | |
| 	}
 | |
| 
 | |
| 	// 管理员列表
 | |
| 	public function userinfo()
 | |
| 	{
 | |
| 		$lists = AdminUser::select();
 | |
| 		$group = [];
 | |
| 		$groups = AdminUserGroup::select();
 | |
| 		foreach ($groups as $key => $value) {
 | |
| 			$group[$value['group_id']] = $value;
 | |
| 		}
 | |
| 		View::assign([
 | |
| 			'lists' => $lists,
 | |
| 			'group' => $group
 | |
| 		]);
 | |
| 		return View::fetch();
 | |
| 	}
 | |
| 
 | |
| 	// 管理员添加
 | |
| 	public function useradd()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$data['account'] = trim(input('post.account'));
 | |
| 			if (empty($data['account'])) {
 | |
| 				Log::record('添加管理员', 0, '账号不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '账号不能为空']);
 | |
| 			}
 | |
| 			$pattern = "/^([0-9A-Za-z-_.]+)@([0-9a-z]+.[a-z]{2,3}(.[a-z]{2})?)$/i";
 | |
| 			if (!preg_match($pattern, $data['account'])) {
 | |
| 				Log::record('添加管理员', 0, '邮箱格式不正确', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '邮箱格式不正确']);
 | |
| 			}
 | |
| 			$item = AdminUser::where('account', $data['account'])->find();
 | |
| 			if ($item) {
 | |
| 				Log::record('添加管理员', 0, '该账号已存在', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '该账号已存在']);
 | |
| 			}
 | |
| 			$data['name'] = trim(input('post.name'));
 | |
| 			$data['phone'] = trim(input('post.phone'));
 | |
| 			$data['qq'] = (int) trim(input('post.qq'));
 | |
| 			$data['group_id'] = (int) input('post.group_id');
 | |
| 			$data['sex'] = (int) (input('post.sex'));
 | |
| 			$data['status'] = (int) (input('post.status'));
 | |
| 			$password = trim(input('post.password'));
 | |
| 			if (empty($data['name'])) {
 | |
| 				Log::record('添加管理员', 0, '姓名不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '姓名不能为空']);
 | |
| 			}
 | |
| 			if (empty($data['phone'])) {
 | |
| 				Log::record('添加管理员', 0, '手机号不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '手机号不能为空']);
 | |
| 			}
 | |
| 			if (empty($data['group_id'])) {
 | |
| 				Log::record('添加管理员', 0, '请选择角色', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '请选择角色']);
 | |
| 			}
 | |
| 			if (empty($password)) {
 | |
| 				Log::record('添加管理员', 0, '密码不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '密码不能为空']);
 | |
| 			} else {
 | |
| 				$data['password'] = md5($password);
 | |
| 			}
 | |
| 			$data['create_time'] = time();
 | |
| 			$data['update_time'] = time();
 | |
| 			$res = AdminUser::insert($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('添加管理员', 0, '添加管理员失败', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '添加管理员失败']);
 | |
| 			}
 | |
| 			Log::record('添加管理员', 1, '', '管理员管理');
 | |
| 			return json(['code' => 0, 'msg' => '添加成功']);
 | |
| 		} else {
 | |
| 			$group = [];
 | |
| 			$groups = AdminUserGroup::select();
 | |
| 			foreach ($groups as $key => $value) {
 | |
| 				$group[$value['group_id']] = $value;
 | |
| 			}
 | |
| 			View::assign([
 | |
| 				'group' => $group
 | |
| 			]);
 | |
| 			return View::fetch();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// 管理员编辑
 | |
| 	public function useredit()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$uid = (int) trim(input('post.uid'));
 | |
| 			$data['name'] = trim(input('post.name'));
 | |
| 			$data['phone'] = trim(input('post.phone'));
 | |
| 			$data['qq'] = (int) trim(input('post.qq'));
 | |
| 			$data['group_id'] = (int) input('post.group_id');
 | |
| 			$data['sex'] = (int) (input('post.sex'));
 | |
| 			$data['status'] = (int) (input('post.status'));
 | |
| 			if (empty($data['name'])) {
 | |
| 				Log::record('编辑管理员', 0, '姓名不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '姓名不能为空']);
 | |
| 			}
 | |
| 			if (empty($data['phone'])) {
 | |
| 				Log::record('编辑管理员', 0, '手机号不能为空', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '手机号不能为空']);
 | |
| 			}
 | |
| 			if (empty($data['group_id'])) {
 | |
| 				Log::record('编辑管理员', 0, '请选择角色', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '请选择角色']);
 | |
| 			}
 | |
| 			$res = AdminUser::where('uid', $uid)->update($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('编辑管理员', 0, '更新管理员信息失败', '管理员管理');
 | |
| 				return json(['code' => 1, 'msg' => '更新管理员信息失败']);
 | |
| 			}
 | |
| 			Log::record('编辑管理员', 1, '', '管理员管理');
 | |
| 			return json(['code' => 0, 'msg' => '更新成功']);
 | |
| 		} else {
 | |
| 			$uid = (int) input('get.uid');
 | |
| 			// 加载管理员
 | |
| 			$lists = AdminUser::where('uid', $uid)->find();
 | |
| 			// 加载角色
 | |
| 			$group = [];
 | |
| 			$groups = AdminUserGroup::select();
 | |
| 			foreach ($groups as $key => $value) {
 | |
| 				$group[$value['group_id']] = $value;
 | |
| 			}
 | |
| 			View::assign([
 | |
| 				'lists' => $lists,
 | |
| 				'group' => $group
 | |
| 			]);
 | |
| 			return View::fetch();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// 管理员删除
 | |
| 	public function userdel()
 | |
| 	{
 | |
| 		$uid = (int) input('post.uid');
 | |
| 		$res = AdminUser::where('uid', $uid)->delete();
 | |
| 		if (empty($res)) {
 | |
| 			Log::record('删除管理员', 0, '删除管理员失败', '管理员管理');
 | |
| 			return json(['code' => 1, 'msg' => '删除管理员失败']);
 | |
| 		}
 | |
| 		Log::record('删除管理员', 1, '', '管理员管理');
 | |
| 		return json(['code' => 0, 'msg' => '删除成功']);
 | |
| 	}
 | |
| 
 | |
| 	// 管理员信息
 | |
| 	public function admininfo()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$find = AdminUser::where('uid', $this->adminId)->find();
 | |
| 			if (empty($find)) {
 | |
| 				Log::record('修改个人信息', 0, '当前账户不存在', '个人信息');
 | |
| 				return json(['code' => 1, 'msg' => '当前账户不存在']);
 | |
| 			}
 | |
| 			$data['name'] = trim(input('post.name'));
 | |
| 			$data['phone'] = trim(input('post.phone'));
 | |
| 			$data['qq'] = (int) trim(input('post.qq'));
 | |
| 			$data['sex'] = (int) (input('post.sex'));
 | |
| 			if (empty($data['name'])) {
 | |
| 				Log::record('修改个人信息', 0, '姓名不能为空', '个人信息');
 | |
| 				return json(['code' => 1, 'msg' => '姓名不能为空']);
 | |
| 			}
 | |
| 			if (empty($data['phone'])) {
 | |
| 				Log::record('修改个人信息', 0, '手机号不能为空', '个人信息');
 | |
| 				return json(['code' => 1, 'msg' => '手机号不能为空']);
 | |
| 			}
 | |
| 
 | |
| 			// 处理密码修改
 | |
| 			$old_pw = trim(input('post.old_pw'));
 | |
| 			$new_pw = trim(input('post.new_pw'));
 | |
| 			if (!empty($old_pw) && !empty($new_pw)) {
 | |
| 				if (md5($old_pw) != $find['password']) {
 | |
| 					Log::record('修改个人信息', 0, '原密码错误', '个人信息');
 | |
| 					return json(['code' => 1, 'msg' => '原密码错误']);
 | |
| 				}
 | |
| 				$data['password'] = md5($new_pw);
 | |
| 			}
 | |
| 
 | |
| 			$res = AdminUser::where('uid', $this->adminId)->update($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('修改个人信息', 0, '更新管理员信息失败', '个人信息');
 | |
| 				return json(['code' => 1, 'msg' => '更新管理员信息失败']);
 | |
| 			}
 | |
| 			Log::record('修改个人信息', 1, '', '个人信息');
 | |
| 			return json(['code' => 0, 'msg' => '更新成功']);
 | |
| 		} else {
 | |
| 			return View::fetch();
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	//banner管理
 | |
| 	public function banner()
 | |
| 	{
 | |
| 		return View::fetch();
 | |
| 	}
 | |
| 
 | |
| 	// banner列表
 | |
| 	public function bannerlist()
 | |
| 	{
 | |
| 		if (Request::isGet()) {
 | |
|             $page = intval(input('post.page', 1));
 | |
|             $limit = intval(input('post.limit', 10));
 | |
| 
 | |
| 			$query = Banner::where('delete_time', null)
 | |
| 				->field('id, title, image, url, sort, create_time, update_time');
 | |
| 
 | |
| 			// 获取总记录数
 | |
| 			$count = $query->count();
 | |
| 
 | |
| 			// 获取分页数据
 | |
| 			$lists = $query->order(['sort DESC', 'id DESC'])
 | |
| 				->page($page, $limit)
 | |
| 				->select()
 | |
| 				->toArray();
 | |
| 
 | |
| 			// 处理数据
 | |
| 			foreach ($lists as &$item) {
 | |
| 				$item['create_time'] = is_numeric($item['create_time']) ? date('Y-m-d H:i:s', $item['create_time']) : $item['create_time'];
 | |
| 				$item['update_time'] = is_numeric($item['update_time']) ? date('Y-m-d H:i:s', $item['update_time']) : $item['update_time'];
 | |
| 			}
 | |
| 
 | |
| 			return json([
 | |
| 				'code' => 0,
 | |
| 				'msg' => '',
 | |
| 				'count' => $count,
 | |
| 				'data' => $lists
 | |
| 			]);
 | |
| 		}
 | |
| 		return json(['code' => 1, 'msg' => '请求方法无效']);
 | |
| 	}
 | |
| 
 | |
| 	// 添加banner
 | |
| 	public function banneradd()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$data = [
 | |
| 				'title' => input('post.title'),
 | |
| 				'image' => input('post.image'),
 | |
| 				'url' => input('post.url'),
 | |
| 				'sort' => input('post.sort', 0),
 | |
| 				'status' => 1,
 | |
| 				'create_time' => time()
 | |
| 			];
 | |
| 
 | |
| 			$res = Banner::insert($data);
 | |
| 			if (!$res) {
 | |
| 				Log::record('添加Banner', 0, '添加Banner失败', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => '添加Banner失败']);
 | |
| 			}
 | |
| 			Log::record('添加Banner', 1, '', 'Banner管理');
 | |
| 			return json(['code' => 0, 'msg' => '添加成功']);
 | |
| 		}
 | |
| 		return json(['code' => 1, 'msg' => '请求方法无效']);
 | |
| 	}
 | |
| 
 | |
| 	// 编辑banner
 | |
| 	public function banneredit()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$id = input('post.id');
 | |
| 			if (empty($id)) {
 | |
| 				Log::record('编辑Banner', 0, 'ID不能为空', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => 'ID不能为空']);
 | |
| 			}
 | |
| 
 | |
| 			$data = [
 | |
| 				'title' => input('post.title'),
 | |
| 				'image' => input('post.image'),
 | |
| 				'url' => input('post.url'),
 | |
| 				'sort' => input('post.sort', 0),
 | |
| 				'update_time' => time()
 | |
| 			];
 | |
| 
 | |
| 			$res = Banner::where('id', $id)->update($data);
 | |
| 			if ($res === false) {
 | |
| 				Log::record('编辑Banner', 0, '更新Banner失败', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => '更新Banner失败']);
 | |
| 			}
 | |
| 			Log::record('编辑Banner', 1, '', 'Banner管理');
 | |
| 			return json(['code' => 0, 'msg' => '更新成功']);
 | |
| 		}
 | |
| 		return json(['code' => 1, 'msg' => '请求方法无效']);
 | |
| 	}
 | |
| 
 | |
| 	// 删除banner
 | |
| 	public function bannerdel()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$id = input('post.id');
 | |
| 			if (empty($id)) {
 | |
| 				Log::record('删除Banner', 0, 'ID不能为空', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => 'ID不能为空']);
 | |
| 			}
 | |
| 
 | |
| 			$res = Banner::where('id', $id)->update(['delete_time' => time()]);
 | |
| 			if (!$res) {
 | |
| 				Log::record('删除Banner', 0, '删除Banner失败', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => '删除Banner失败']);
 | |
| 			}
 | |
| 			Log::record('删除Banner', 1, '', 'Banner管理');
 | |
| 			return json(['code' => 0, 'msg' => '删除成功']);
 | |
| 		}
 | |
| 		return json(['code' => 1, 'msg' => '请求方法无效']);
 | |
| 	}
 | |
| 
 | |
| 	// 修改banner状态
 | |
| 	public function bannerstatus()
 | |
| 	{
 | |
| 		if (Request::isPost()) {
 | |
| 			$id = input('post.id');
 | |
| 			$status = input('post.status');
 | |
| 
 | |
| 			if (empty($id)) {
 | |
| 				Log::record('修改Banner状态', 0, 'ID不能为空', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => 'ID不能为空']);
 | |
| 			}
 | |
| 
 | |
| 			$res = Banner::where('id', $id)->update(['status' => $status]);
 | |
| 			if ($res === false) {
 | |
| 				Log::record('修改Banner状态', 0, '更新状态失败', 'Banner管理');
 | |
| 				return json(['code' => 1, 'msg' => '更新状态失败']);
 | |
| 			}
 | |
| 			Log::record('修改Banner状态', 1, '', 'Banner管理');
 | |
| 			return json(['code' => 0, 'msg' => '更新成功']);
 | |
| 		}
 | |
| 		return json(['code' => 1, 'msg' => '请求方法无效']);
 | |
| 	}
 | |
| 
 | |
| } |