297 lines
8.2 KiB
PHP
297 lines
8.2 KiB
PHP
<?php
|
||
namespace app\index\controller;
|
||
|
||
use app\common\controller\BaseController;
|
||
use app\common\validate\User as userValidate;
|
||
use think\exception\ValidateException;
|
||
use think\facade\Db;
|
||
use think\facade\Request;
|
||
use think\facade\Session;
|
||
use think\facade\Cache;
|
||
use think\facade\Cookie;
|
||
use think\facade\View;
|
||
use app\common\model\Article;
|
||
use app\common\model\Collection;
|
||
use app\common\model\User as userModel;
|
||
use app\common\model\Comment;
|
||
use taoler\com\Message;
|
||
|
||
class User extends BaseController
|
||
{
|
||
protected $middleware = [
|
||
'logincheck' => ['except' => ['home'] ],
|
||
];
|
||
|
||
//用户中心
|
||
public function index()
|
||
{
|
||
return view();
|
||
}
|
||
|
||
|
||
// 发帖list
|
||
public function artList()
|
||
{
|
||
$article = Article::withCount('comments')->where(['user_id'=>$this->uid])->order('update_time','desc')->paginate(10);
|
||
$count = $article->total();
|
||
$res = [];
|
||
if($count){
|
||
$res['code'] = 0;
|
||
$res['count'] = $count;
|
||
foreach($article as $v){
|
||
$res['data'][] = ['id'=>$v['id'],
|
||
'title' => htmlspecialchars($v['title']),
|
||
'url' => (string) url('article/detail',['id'=>$v['id']]),
|
||
'url' => $this->getRouteUrl($v['id'], $v->cate->ename),
|
||
'status' => $v['status'] ? '正常':'待审核',
|
||
'ctime' => $v['create_time'],
|
||
'datas' => $v['pv'].'阅/'.$v['comments_count'].'答'
|
||
];
|
||
}
|
||
|
||
} else {
|
||
return json(['code'=>-1,'msg'=>'无数据']);
|
||
}
|
||
return json($res);
|
||
}
|
||
|
||
// 收藏list
|
||
public function collList()
|
||
{
|
||
//收藏的帖子
|
||
$collect = Collection::with(['article'=>function($query){
|
||
$query->withCount('comments')->where('status',1);
|
||
}])->where('user_id',$this->uid)->order('create_time','desc')->paginate(10);
|
||
$count =$collect->total();
|
||
$res = [];
|
||
if($count){
|
||
$res['code'] = 0;
|
||
$res['count'] = $count ;
|
||
foreach($collect as $v){
|
||
|
||
$res['data'][] = [
|
||
'id' =>$v['id'],
|
||
'title' => htmlspecialchars($v['collect_title']),
|
||
'url' => $this->getRouteUrl($v['article_id'], $v->article->cate->ename),
|
||
'auther' => $v['auther'],
|
||
'status' => is_null(Db::name('article')->field('id')->where('delete_time',0)->find($v['article_id'])) ? '已失效' : '正常',
|
||
'ctime' => $v['create_time']
|
||
];
|
||
}
|
||
|
||
} else {
|
||
return json(['code'=>-1,'msg'=>'无数据']);
|
||
}
|
||
return json($res);
|
||
}
|
||
|
||
|
||
|
||
//文章管理
|
||
public function post()
|
||
{
|
||
return View::fetch();
|
||
}
|
||
|
||
//取消文章收藏
|
||
public function colltDel()
|
||
{
|
||
if(Request::isAjax()){
|
||
$collt = Collection::where('user_id',$this->uid)->find(input('id'));
|
||
$result = $collt->delete();
|
||
if($result){
|
||
$res = ['code'=>0,'msg'=>'取消成功'];
|
||
} else {
|
||
$res = ['code'=>0,'msg'=>'取消失败'];
|
||
}
|
||
return json($res);
|
||
}
|
||
}
|
||
|
||
//用户设置-我的资料
|
||
public function set()
|
||
{
|
||
if(Request::isAjax()){
|
||
$data = Request::only(['user_id','email','nickname','sex','city','area_id','sign']);
|
||
// 过滤
|
||
$sign = strtolower($data['sign']);
|
||
if(strstr($sign, 'script')) return json(['code'=>-1,'msg'=>'包含有非法字符串script脚本']);
|
||
if(strstr($sign, 'alert')) return json(['code'=>-1,'msg'=>'包含有非法字符alert']);
|
||
if(strstr($sign, 'img')) return json(['code'=>-1,'msg'=>'禁用img标签']);
|
||
if(strstr($sign, 'body')) return json(['code'=>-1,'msg'=>'禁用img标签']);
|
||
if(strstr($sign, 'video')) return json(['code'=>-1,'msg'=>'禁用video标签']);
|
||
|
||
// 验证
|
||
$validate = new userValidate;
|
||
$result = $validate->scene('Set')->check($data);
|
||
if(!$result){
|
||
$this->error($validate->getError());
|
||
} else {
|
||
//防止重复的email
|
||
$resEmail = Db::name('user')->where('email',$data['email'])->where('id','<>',$this->uid)->find();
|
||
if(!is_null($resEmail)){
|
||
return ['code'=>-1,'msg'=>'email已存在,请更换!'];
|
||
}
|
||
//若更换email,需重新激活
|
||
$mail = Db::name('user')->where('id',$this->uid)->value('email');
|
||
if($data['email'] !== $mail){
|
||
$data['active'] = 0;
|
||
}
|
||
$user = new userModel;
|
||
$result = $user->setNew($data);
|
||
if($result == 1){
|
||
Cache::tag('user')->clear();
|
||
return json(['code'=>0,'msg'=>'资料更新成功']);
|
||
} else {
|
||
$this->error($result);
|
||
}
|
||
}
|
||
}
|
||
$area = Db::name('user_area')->select();
|
||
View::assign(['area'=>$area]);
|
||
return View::fetch();
|
||
}
|
||
|
||
//更换头像
|
||
public function uploadHeadImg()
|
||
{
|
||
$uploads = new \app\common\lib\Uploads();
|
||
$upRes = $uploads->put('file','head_img',1024,'image','uniqid');
|
||
$upHeadRes = $upRes->getData();
|
||
if($upHeadRes['status'] == 0){
|
||
$name_path = $upHeadRes['url'];
|
||
//$name = $file->hashName();
|
||
//$image = \think\Image::open("uploads/$name_path");
|
||
//$image->thumb(168, 168)->save("uploads/$name_path");
|
||
|
||
//查出当前用户头像删除原头像并更新
|
||
$imgPath = Db::name('user')->where('id',$this->uid)->value('user_img');
|
||
if(file_exists('.'.$imgPath)){
|
||
$dirPath = dirname('.'.$imgPath);
|
||
if($dirPath !== './static/res/images/avatar'){ //防止删除默认头像
|
||
unlink('.'.$imgPath);
|
||
}
|
||
}
|
||
$result = Db::name('user')
|
||
->where('id',$this->uid)
|
||
->update(['user_img'=>$name_path]);
|
||
Cache::tag(['user','tagArtDetail','tagArt'])->clear();
|
||
if($result) {
|
||
$res = ['code'=>0,'msg'=>'头像更新成功'];
|
||
} else {
|
||
$res = ['code'=>1,'msg'=>'头像更新失败'];
|
||
}
|
||
} else {
|
||
$res = ['code'=>1,'msg'=>'上传错误'];
|
||
}
|
||
return json($res);
|
||
}
|
||
|
||
|
||
public function message()
|
||
{
|
||
$uid = Session::get('user_id');
|
||
$msg = Message::receveMsg($uid);
|
||
|
||
View::assign('msg',$msg);
|
||
return View::fetch();
|
||
}
|
||
|
||
//个人页
|
||
public function home($id)
|
||
{
|
||
//用户
|
||
$u = Cache::get('user'.$id);
|
||
if(!$u){
|
||
$u = Db::name('user')->field('name,nickname,city,sex,sign,user_img,point,vip,create_time')->cache(3600)->find($id);
|
||
}
|
||
|
||
$article = new Article();
|
||
// $commont = new Comment();
|
||
$arts = $article->getUserArtList((int) $id);
|
||
|
||
// $reys = $commont->getUserCommentList((int) $id);
|
||
// dump($reys);
|
||
//用户回答
|
||
$reys = Db::name('comment')
|
||
->alias('c')
|
||
->join('article a','c.article_id = a.id')
|
||
->field('a.id,a.title,c.content,c.create_time,c.delete_time,c.status')
|
||
->where(['a.delete_time'=>0,'c.delete_time'=>0,'c.status'=>1])
|
||
->where('c.user_id',$id)
|
||
->order(['c.create_time'=>'desc'])
|
||
->cache(3600)->select();
|
||
|
||
View::assign(['u'=>$u,'arts'=>$arts,'reys'=>$reys,'jspage'=>'']);
|
||
return View::fetch();
|
||
}
|
||
|
||
|
||
public function layout()
|
||
{
|
||
return View::fetch();
|
||
}
|
||
|
||
//邮箱激活
|
||
public function activate()
|
||
{
|
||
//管理员邮箱
|
||
$adminEmail = Db::name('user')->where('id',1)->cache(true)->value('email');
|
||
View::assign('adminEmail',$adminEmail);
|
||
return View::fetch();
|
||
}
|
||
|
||
//邮箱激活
|
||
public function active()
|
||
{
|
||
|
||
if(Request::isPost()){
|
||
$email = Request::param('email');
|
||
$url = Request::domain().Request::root().'/active/index?url='.time().md5($email).$this->uid;
|
||
$content = "Hi亲爱的{$this->showUser($this->uid)['name']}:</br>您正在进行邮箱激活,请在10分钟内完成激活。 <a href='{$url}' target='_blank' >请点击进行激活</a> </br>若无法跳转请复制链接激活:{$url}";
|
||
$res = mailto($email,'邮箱激活',$content);
|
||
if($res){
|
||
return json(['status'=>0]);
|
||
}else{
|
||
return json(['status'=>-1,'发送邮件出错!']);
|
||
}
|
||
}
|
||
}
|
||
|
||
//修改密码
|
||
public function setPass()
|
||
{
|
||
if(Request::isAjax()){
|
||
$data = Request::param();
|
||
$validate = new userValidate;
|
||
$res = $validate->scene('setPass')->check($data);
|
||
if(!$res){
|
||
return $this->error($validate->getError());
|
||
}
|
||
$user = new userModel;
|
||
$result = $user->setpass($data);
|
||
if($result == 1) {
|
||
Session::clear();
|
||
Cookie::delete('auth');
|
||
return $this->success('密码修改成功 请登录', (string) url('login/index'));
|
||
} else {
|
||
return $this->error($result);
|
||
}
|
||
}
|
||
}
|
||
|
||
//退出账户
|
||
public function logout()
|
||
{
|
||
Session::clear();
|
||
Cookie::delete('auth');
|
||
//Cookie::delete('user_name');
|
||
//Cookie::delete('user_id');
|
||
if(Session::has('user_id')){
|
||
return json(['code' => -1, 'msg' => '退出失败']);
|
||
} else {
|
||
return json(['code' => 200, 'msg' => '退出成功', 'url' => '/']);
|
||
}
|
||
}
|
||
|
||
} |