186 lines
4.5 KiB
PHP
186 lines
4.5 KiB
PHP
<?php
|
|
|
|
namespace app\admin\controller\user;
|
|
|
|
use app\common\controller\AdminController;
|
|
use app\admin\validate\Admin;
|
|
use think\facade\View;
|
|
use think\facade\Request;
|
|
use think\facade\Db;
|
|
use app\common\model\User as UserModel;
|
|
use app\common\lib\Uploads;
|
|
|
|
class User extends AdminController
|
|
{
|
|
|
|
/**
|
|
* 浏览
|
|
*
|
|
* @return void
|
|
*/
|
|
public function index()
|
|
{
|
|
return View::fetch();
|
|
}
|
|
//用户表
|
|
|
|
public function list()
|
|
{
|
|
if(Request::isAjax()){
|
|
$datas = Request::only(['id','name','email','sex','status']);
|
|
$map = array_filter($datas,[$this,'filtrArr']);
|
|
$user = Db::name('user')->where(['delete_time'=>0])->where($map)->order('id desc')->paginate(30);
|
|
$count = $user->total();
|
|
$res = [];
|
|
if($count){
|
|
$res = ['code'=>0,'msg'=>'ok','count'=>$count];
|
|
foreach($user as $k => $v){
|
|
$data = [
|
|
'id' => $v['id'],
|
|
'username' => $v['name'],
|
|
'nick' => $v['nickname'],
|
|
'avatar' => $v['user_img'],
|
|
'phone' => $v['phone'],
|
|
'email' => $v['email'],
|
|
'sex' => $v['sex'],
|
|
'ip' => $v['last_login_ip'],
|
|
'city' => $v['city'],
|
|
'logintime' => date("Y-m-d H:i",$v['last_login_time']),
|
|
'jointime' => date("Y-m-d",$v['create_time']),
|
|
'check' => $v['status'],
|
|
'auth' => $v['auth']
|
|
];
|
|
$res['data'][] = $data;
|
|
}
|
|
} else {
|
|
$res = ['code'=>-1,'msg'=>'没有查询结果!'];
|
|
}
|
|
return json($res);
|
|
}
|
|
return View::fetch();
|
|
}
|
|
|
|
|
|
//添加用户
|
|
public function add()
|
|
{
|
|
//
|
|
if(Request::isAjax()){
|
|
$data = Request::only(['name','email','user_img','password','phone','sex']);
|
|
$data['create_time'] = time();
|
|
$salt = substr(md5($data['create_time']),-6);
|
|
// 密码
|
|
$data['password'] = md5(substr_replace(md5($data['password']),$salt,0,6));
|
|
try {
|
|
Db::name('user')->save($data);
|
|
$res = ['code'=>0,'msg'=>'添加成功'];
|
|
} catch (\Exception $e) {
|
|
$res = ['code'=>-1, 'msg'=>$e->getMessage()];
|
|
}
|
|
return json($res);
|
|
}
|
|
|
|
return View::fetch();
|
|
}
|
|
|
|
//编辑用户
|
|
public function edit()
|
|
{
|
|
if(Request::isAjax()){
|
|
$data = Request::only(['name','email','user_img','password','phone','sex']);
|
|
$user = Db::name('user')->field('create_time')->find($data['id']);
|
|
$salt = substr(md5($user['create_time']),-6);
|
|
// 密码
|
|
$data['password'] = md5(substr_replace(md5($data['password']),$salt,0,6));
|
|
|
|
$result = Db::name('user')->update($data);
|
|
if($result){
|
|
$res = ['code'=>0,'msg'=>'编辑成功'];
|
|
}else{
|
|
$res = ['code'=>-1,'msg'=>'编辑失败'];
|
|
}
|
|
return json($res);
|
|
}
|
|
$user = Db::name('user')->find(input('id'));
|
|
View::assign('user',$user);
|
|
return View::fetch();
|
|
}
|
|
|
|
//删除用户
|
|
public function delete($id)
|
|
{
|
|
$ids = explode(',',$id);
|
|
if(Request::isAjax()){
|
|
$user =UserModel::select($ids);
|
|
$result = $user->delete();
|
|
|
|
if($result){
|
|
return json(['code'=>0,'msg'=>'删除成功']);
|
|
}else{
|
|
return json(['code'=>-1,'msg'=>'删除失败']);
|
|
}
|
|
}
|
|
}
|
|
|
|
//上传头像
|
|
public function uploadImg()
|
|
{
|
|
$uploads = new Uploads();
|
|
$upRes = $uploads->put('file','head_pic',2000,'image');
|
|
$userJson = $upRes->getData();
|
|
if($userJson['status'] == 0){
|
|
$res = ['code'=>0,'msg'=>'上传头像成功','src'=>$userJson['url']];
|
|
} else {
|
|
$res = ['code'=>1,'msg'=>'上传错误'];
|
|
}
|
|
return json($res);
|
|
}
|
|
|
|
|
|
//审核用户
|
|
public function check()
|
|
{
|
|
$data = Request::only(['id','status']);
|
|
//获取状态
|
|
$res = Db::name('user')->where('id',$data['id'])->save(['status' => $data['status']]);
|
|
if($res){
|
|
if($data['status'] == 1){
|
|
return json(['code'=>0,'msg'=>'用户审核通过','icon'=>6]);
|
|
} else {
|
|
return json(['code'=>0,'msg'=>'禁用用户','icon'=>5]);
|
|
}
|
|
|
|
}else {
|
|
return json(['code'=>-1,'msg'=>'审核出错']);
|
|
}
|
|
|
|
}
|
|
|
|
//超级管理员
|
|
public function auth()
|
|
{
|
|
$data = Request::param();
|
|
$user = Db::name('user')->save($data);
|
|
if($user){
|
|
if($data['auth'] == 1){
|
|
return json(['code'=>0,'msg'=>'设置为超级管理员','icon'=>6]);
|
|
} else {
|
|
return json(['code'=>0,'msg'=>'取消超级管理员','icon'=>5]);
|
|
}
|
|
}else{
|
|
$res = ['code'=>-1,'msg'=>'前台管理员设置失败'];
|
|
}
|
|
return json($res);
|
|
}
|
|
|
|
//过滤数组中为空和null的值
|
|
public function filtrArr($arr)
|
|
{
|
|
if($arr === '' || $arr === null){
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
}
|