TaoLer/app/index/controller/User.php

396 lines
12 KiB
PHP
Raw Normal View History

2020-01-01 13:17:19 +08:00
<?php
namespace app\index\controller;
use app\common\controller\BaseController;
use app\common\validate\User as userValidate;
use think\facade\Db;
use think\facade\Request;
use think\facade\Session;
use think\facade\Cache;
2020-10-12 11:19:19 +08:00
use think\facade\Cookie;
2020-01-01 13:17:19 +08:00
use think\facade\View;
use app\common\model\Article;
use app\common\model\Collection;
use app\common\model\User as userModel;
2020-03-29 19:57:18 +08:00
use taoler\com\Message;
2020-01-01 13:17:19 +08:00
class User extends BaseController
{
protected $middleware = [
'logincheck' => ['except' => ['home'] ],
];
//用户中心
public function index()
{
return view();
}
2021-05-24 15:05:30 +08:00
2023-03-16 22:30:36 +08:00
// 我的发帖list
2021-05-24 15:05:30 +08:00
public function artList()
2020-01-01 13:17:19 +08:00
{
2023-03-16 22:30:36 +08:00
$param = Request::only(['page','limit']);
2024-04-01 10:17:53 +08:00
$myArticle = Article::field('id,cate_id,title,status,pv,create_time,update_time')
2023-03-16 22:30:36 +08:00
->withCount(['comments'])
->where(['user_id'=>$this->uid])
->order('update_time','desc')
->paginate([
'list_rows' => $param['limit'],
2024-04-01 10:17:53 +08:00
'page' => $param['page']
2023-03-16 22:30:36 +08:00
]);
$count = $myArticle->total();
2021-05-24 15:05:30 +08:00
$res = [];
if($count){
$res['code'] = 0;
$res['count'] = $count;
2023-03-16 22:30:36 +08:00
foreach($myArticle as $v){
2021-05-24 15:05:30 +08:00
$res['data'][] = ['id'=>$v['id'],
2021-12-10 19:35:12 +08:00
'title' => htmlspecialchars($v['title']),
2023-03-16 22:30:36 +08:00
'url' => $this->getRouteUrl($v['id'], $v->cate->ename, $v->cate->appname),
2024-04-14 12:03:38 +08:00
'status' => $this->artStatus($v['status']),
2021-05-24 15:05:30 +08:00
'ctime' => $v['create_time'],
2024-04-01 10:17:53 +08:00
'utime' => $v['update_time'],
'pv' => $v['pv'],
'datas' => $v['comments_count'].'答'
2021-05-24 15:05:30 +08:00
];
}
2024-04-01 10:17:53 +08:00
return json($res);
2021-05-24 15:05:30 +08:00
}
2024-04-01 10:17:53 +08:00
return json(['code'=>-1,'msg'=>'无数据']);
2021-05-24 15:05:30 +08:00
}
2024-04-14 12:03:38 +08:00
// 文章状态
private function artStatus($status)
{
switch ($status) {
case 1:
$res = '正常';
break;
case -1:
$res = '禁止';
break;
default:
$res = '待审';
break;
}
return $res;
}
2021-05-24 15:05:30 +08:00
2022-08-02 21:13:36 +08:00
// 收藏list
public function collList()
{
2020-01-01 13:17:19 +08:00
//收藏的帖子
2021-05-24 15:05:30 +08:00
$collect = Collection::with(['article'=>function($query){
$query->withCount('comments')->where('status',1);
}])->where('user_id',$this->uid)->order('create_time','desc')->paginate(10);
2020-01-01 13:17:19 +08:00
$count =$collect->total();
2021-05-24 15:05:30 +08:00
$res = [];
if($count){
$res['code'] = 0;
$res['count'] = $count ;
foreach($collect as $v){
$res['data'][] = [
'id' =>$v['id'],
2021-12-10 19:35:12 +08:00
'title' => htmlspecialchars($v['collect_title']),
2022-08-02 21:13:36 +08:00
'url' => $this->getRouteUrl($v['article_id'], $v->article->cate->ename),
2021-05-25 18:17:45 +08:00
'auther' => $v['auther'],
'status' => is_null(Db::name('article')->field('id')->where('delete_time',0)->find($v['article_id'])) ? '已失效' : '正常',
'ctime' => $v['create_time']
2021-05-24 15:05:30 +08:00
];
}
} else {
return json(['code'=>-1,'msg'=>'无数据']);
}
return json($res);
}
//文章管理
public function post()
{
2020-01-01 13:17:19 +08:00
return View::fetch();
}
2024-04-01 10:17:53 +08:00
// 编辑pv
public function edtiPv()
{
if(Request::isAjax()){
$param = Request::param(['id','pv']);
$res = Db::name('article')->save(['id' => $param['id'], 'pv' => $param['pv']]);
if($res) {
return json(['code' => 0, 'msg' => '修改成功!']);
}
}
return json(['code' => -1, 'msg' => '修改失败!']);
}
// 刷新
public function updateTime()
{
if(Request::isAjax()){
$param = Request::param(['data']);
if(count($param) == 0) return json(['code' => -1, 'msg' => '未选中任何数据!']);
$idArr = [];
foreach($param['data'] as $v) {
$idArr[] = $v['id'];
}
$count = count($idArr);
// vip每天可刷新数
2024-04-01 10:22:13 +08:00
$user = Db::name('user')->field('id,vip,point,auth')->find($this->uid);
2024-04-01 10:17:53 +08:00
$refreshRule = Db::name('user_viprule')->field('refreshnum,refreshpoint')->where('vip', $user['vip'])->find();
// 检测刷新帖子剩余量
$refreshLog = Db::name('user_article_log')->field('id,user_refreshnum')->where(['user_id' => $this->uid])->whereDay('create_time')->find();
if(is_null($refreshLog)) {// 新增
Db::name('user_article_log')->save(['user_id' => $this->uid, 'create_time' => time()]);
$refreshLog = Db::name('user_article_log')->field('id,user_refreshnum')->where(['user_id' => $this->uid])->whereDay('create_time')->find();
}
2024-04-01 10:22:13 +08:00
// 超级管理员排外
if($user['auth'] === '0') {
$cannum = $refreshRule['refreshnum'] - $refreshLog['user_refreshnum']; // 可用免费数
// 刷帖先扣积分
if($cannum <= 0) { // a.免费额已用完 后面需要积分
$canpoint = $count * $refreshRule['refreshpoint'];
2024-04-01 10:17:53 +08:00
$point = $user['point'] - $canpoint;
if($point < 0) {
// 1.积分不足
2024-04-01 10:22:13 +08:00
return json(['code' => -1, 'msg' => "免额已使用,本次需{$canpoint}积分,请充值!"]);
2024-04-01 10:17:53 +08:00
} else {
// 2.扣除积分
Db::name('user')->where('id', $this->uid)->update(['point' => $point]);
}
2024-04-01 10:22:13 +08:00
} else { // b.未超限 有剩余条数
if($count > $cannum) { // 本次刷新数量大于剩余免费数量,需要支付积分
$canpoint = ($count - $cannum) * $refreshRule['refreshpoint'];
$point = $user['point'] - $canpoint;
if($point < 0) {
// 1.积分不足
return json(['code' => -1, 'msg' => "免额已使用,本次需{$canpoint}积分,额度不足请充值!"]);
} else {
// 2.扣除积分
Db::name('user')->where('id', $this->uid)->update(['point' => $point]);
}
}
2024-04-01 10:17:53 +08:00
}
}
// 刷新数据
$res = Db::name('article')->where('id', 'in', $idArr)->update(['update_time' => time()]);
if($res > 0) {
// 记录刷帖日志
Db::name('user_article_log')->where('id', $refreshLog['id'])->inc('user_refreshnum', $count)->update();
return json(['code' => 0, 'msg' => '刷新成功!']);
}
}
return json(['code' => -1, 'msg' => '刷新失败!']);
}
2020-01-01 13:17:19 +08:00
//取消文章收藏
public function colltDel()
{
2021-05-24 15:05:30 +08:00
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);
2020-01-01 13:17:19 +08:00
}
}
//用户设置-我的资料
public function set()
{
if(Request::isAjax()){
2024-04-01 10:17:53 +08:00
$data = Request::only(['email','phone','nickname','sex','city','area_id','sign']);
2023-03-16 22:35:59 +08:00
$data['user_id'] = $this->uid;
2022-08-02 21:13:36 +08:00
// 过滤
$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;
2020-01-01 13:17:19 +08:00
$result = $validate->scene('Set')->check($data);
if(!$result){
2023-07-03 12:56:37 +08:00
return json(['code'=>-1,'msg' =>$validate->getError()]);
2020-01-01 13:17:19 +08:00
} else {
2021-10-12 16:50:02 +08:00
//防止重复的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;
2020-01-01 13:17:19 +08:00
$result = $user->setNew($data);
if($result == 1){
Cache::tag('user')->clear();
2022-08-02 21:13:36 +08:00
return json(['code'=>0,'msg'=>'资料更新成功']);
2020-01-01 13:17:19 +08:00
} else {
2023-07-03 12:56:37 +08:00
return json(['code'=>-1,'msg' =>$result]);
2020-01-01 13:17:19 +08:00
}
}
}
$area = Db::name('user_area')->select();
View::assign(['area'=>$area]);
2020-01-01 13:17:19 +08:00
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'];
2020-01-01 13:17:19 +08:00
//$name = $file->hashName();
//$image = \think\Image::open("uploads/$name_path");
//$image->thumb(168, 168)->save("uploads/$name_path");
2021-05-26 17:57:00 +08:00
//查出当前用户头像删除原头像并更新
$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);
}
}
2020-01-01 13:17:19 +08:00
$result = Db::name('user')
2021-05-26 17:57:00 +08:00
->where('id',$this->uid)
2020-01-01 13:17:19 +08:00
->update(['user_img'=>$name_path]);
2020-05-15 17:04:04 +08:00
Cache::tag(['user','tagArtDetail','tagArt'])->clear();
2020-01-01 13:17:19 +08:00
if($result) {
2022-08-02 21:13:36 +08:00
$res = ['code'=>0,'msg'=>'头像更新成功'];
2020-01-01 13:17:19 +08:00
} else {
2022-08-02 21:13:36 +08:00
$res = ['code'=>1,'msg'=>'头像更新失败'];
2020-01-01 13:17:19 +08:00
}
} else {
2022-08-02 21:13:36 +08:00
$res = ['code'=>1,'msg'=>'上传错误'];
2020-01-01 13:17:19 +08:00
}
2022-08-02 21:13:36 +08:00
return json($res);
2020-01-01 13:17:19 +08:00
}
public function message()
{
2020-03-28 21:41:07 +08:00
$uid = Session::get('user_id');
$msg = Message::receveMsg($uid);
View::assign('msg',$msg);
return View::fetch();
2020-01-01 13:17:19 +08:00
}
//个人页
2020-03-15 18:38:56 +08:00
public function home($id)
2020-01-01 13:17:19 +08:00
{
//用户
2024-04-14 12:08:53 +08:00
$u = Db::name('user')->field('name,nickname,city,sex,sign,user_img,point,vip,create_time')->find($id);
2024-04-14 12:10:25 +08:00
2022-08-02 21:13:36 +08:00
$article = new Article();
$arts = $article->getUserArtList((int) $id);
2020-01-01 13:17:19 +08:00
//用户回答
2022-11-18 10:31:44 +08:00
// $commont = new Comment();
// $reys = $commont->getUserCommentList((int) $id);
2022-08-02 21:13:36 +08:00
$reys = Db::name('comment')
->alias('c')
->join('article a','c.article_id = a.id')
2022-11-18 10:31:44 +08:00
->join('cate t','a.cate_id = t.id')
->field('a.id,a.title,t.ename,c.content,c.create_time,c.delete_time,c.status')
2022-08-02 21:13:36 +08:00
->where(['a.delete_time'=>0,'c.delete_time'=>0,'c.status'=>1])
->where('c.user_id',$id)
2024-04-14 12:08:53 +08:00
->order(['c.id'=>'desc'])
2024-04-01 10:22:13 +08:00
->limit(10)
2022-08-02 21:13:36 +08:00
->cache(3600)->select();
2022-11-18 10:31:44 +08:00
2021-05-24 15:05:30 +08:00
View::assign(['u'=>$u,'arts'=>$arts,'reys'=>$reys,'jspage'=>'']);
2020-01-01 13:17:19 +08:00
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}";
2022-11-20 21:56:09 +08:00
$res = hook('mailtohook',[$email,'邮箱激活',$content]);
if($res){
return json(['status'=>0]);
}else{
return json(['status'=>-1,'发送邮件出错!']);
}
}
2020-01-01 13:17:19 +08:00
}
//修改密码
public function setPass()
2020-01-01 13:17:19 +08:00
{
if(Request::isAjax()){
$data = Request::param();
$validate = new userValidate;
2020-01-01 13:17:19 +08:00
$res = $validate->scene('setPass')->check($data);
if(!$res){
2023-07-03 12:56:37 +08:00
return json(['code'=>-1,'msg' =>$validate->getError()]);
2020-01-01 13:17:19 +08:00
}
2024-04-01 10:17:53 +08:00
$user = new userModel;
$result = $user->setpass($data);
2020-01-01 13:17:19 +08:00
if($result == 1) {
Session::clear();
Cookie::delete('auth');
2024-04-01 10:17:53 +08:00
return json(['code' => 1, 'msg' => '密码修改成功', 'data' => ['url' => (string) url('login/index')]]);
2020-01-01 13:17:19 +08:00
}
2024-04-01 10:17:53 +08:00
return json(['code' => -1,'msg' =>$result]);
2020-01-01 13:17:19 +08:00
}
}
//退出账户
public function logout()
{
Session::clear();
2020-10-16 13:51:56 +08:00
Cookie::delete('auth');
//Cookie::delete('user_name');
//Cookie::delete('user_id');
if(Session::has('user_id')){
return json(['code' => -1, 'msg' => '退出失败']);
}
2023-07-03 12:56:37 +08:00
return json(['code' => 200, 'msg' => '退出成功', 'url' => '/']);
2020-01-01 13:17:19 +08:00
}
}