2020-01-01 13:17:19 +08:00
|
|
|
|
<?php
|
2020-11-27 16:25:08 +08:00
|
|
|
|
declare (strict_types = 1);
|
|
|
|
|
|
2020-01-01 13:17:19 +08:00
|
|
|
|
namespace app\common\model;
|
|
|
|
|
|
|
|
|
|
use think\Model;
|
|
|
|
|
use think\model\concern\SoftDelete;
|
2020-11-25 15:29:48 +08:00
|
|
|
|
use think\facade\Cache;
|
2021-08-04 18:44:24 +08:00
|
|
|
|
use think\facade\Config;
|
2020-01-01 13:17:19 +08:00
|
|
|
|
|
|
|
|
|
class Article extends Model
|
|
|
|
|
{
|
|
|
|
|
protected $autoWriteTimestamp = true; //开启自动时间戳
|
|
|
|
|
protected $createTime = 'create_time';
|
|
|
|
|
protected $updateTime = 'update_time';
|
|
|
|
|
//开启自动设置
|
|
|
|
|
protected $auto = [];
|
|
|
|
|
//仅新增有效
|
|
|
|
|
protected $insert = ['create_time','status'=>1,'is_top'=>0,'is_hot'=>0];
|
|
|
|
|
//仅更新有效
|
|
|
|
|
protected $update = ['update_time'];
|
|
|
|
|
|
|
|
|
|
//软删除
|
|
|
|
|
use SoftDelete;
|
|
|
|
|
protected $deleteTime = 'delete_time';
|
|
|
|
|
protected $defaultSoftDelete = 0;
|
|
|
|
|
|
|
|
|
|
//文章关联栏目表
|
|
|
|
|
public function cate()
|
|
|
|
|
{
|
2022-09-23 11:03:10 +08:00
|
|
|
|
return $this->belongsTo(Cate::class);
|
2020-01-01 13:17:19 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//文章关联评论
|
|
|
|
|
public function comments()
|
|
|
|
|
{
|
2020-02-12 15:08:52 +08:00
|
|
|
|
return $this->hasMany(Comment::class);
|
2020-01-01 13:17:19 +08:00
|
|
|
|
}
|
|
|
|
|
|
2021-05-24 15:05:30 +08:00
|
|
|
|
//文章关联收藏
|
|
|
|
|
public function collection()
|
|
|
|
|
{
|
|
|
|
|
return $this->hasMany(Collection::class);
|
|
|
|
|
}
|
2022-08-02 21:13:36 +08:00
|
|
|
|
|
|
|
|
|
//文章关联用户点赞
|
|
|
|
|
public function userzan()
|
|
|
|
|
{
|
|
|
|
|
return $this->hasMany(UserZan::class);
|
|
|
|
|
}
|
2021-05-24 15:05:30 +08:00
|
|
|
|
|
2020-01-01 13:17:19 +08:00
|
|
|
|
//文章关联用户
|
|
|
|
|
public function user()
|
|
|
|
|
{
|
|
|
|
|
return $this->belongsTo('User','user_id','id');
|
|
|
|
|
}
|
2020-11-27 16:25:08 +08:00
|
|
|
|
|
2022-08-16 15:29:04 +08:00
|
|
|
|
//文章关联Tag表
|
|
|
|
|
public function taglist()
|
|
|
|
|
{
|
|
|
|
|
return $this->hasMany(Taglist::class);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 16:25:08 +08:00
|
|
|
|
/**
|
|
|
|
|
* 添加
|
|
|
|
|
* @param array $data
|
|
|
|
|
* @return int|string
|
|
|
|
|
*/
|
|
|
|
|
public function add(array $data)
|
2020-01-01 13:17:19 +08:00
|
|
|
|
{
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$superAdmin = User::where('id',$data['user_id'])->value('auth');
|
|
|
|
|
// 超级管理员无需审核
|
2021-10-12 16:46:49 +08:00
|
|
|
|
$data['status'] = $superAdmin ? 1 : Config::get('taoler.config.posts_check');
|
2021-08-04 18:44:24 +08:00
|
|
|
|
$msg = $data['status'] ? '发布成功' : '发布成功,请等待审核';
|
2020-01-01 13:17:19 +08:00
|
|
|
|
$result = $this->save($data);
|
2022-08-16 15:29:04 +08:00
|
|
|
|
if($result == true) {
|
|
|
|
|
return ['code' => 1, 'msg' => $msg, 'data' => ['status' => $data['status'], 'id'=> $this->id]];
|
2020-01-01 13:17:19 +08:00
|
|
|
|
} else {
|
2022-08-16 15:29:04 +08:00
|
|
|
|
return ['code' => -1, 'msg'=> '添加文章失败'];
|
2020-01-01 13:17:19 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-11-27 16:25:08 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 编辑
|
|
|
|
|
* @param array $data
|
|
|
|
|
* @return int|string
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
|
|
|
|
public function edit(array $data)
|
2020-01-01 13:17:19 +08:00
|
|
|
|
{
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$article = $this::find($data['id']);
|
2020-01-01 13:17:19 +08:00
|
|
|
|
$result = $article->save($data);
|
|
|
|
|
if($result) {
|
|
|
|
|
return 1;
|
|
|
|
|
} else {
|
2020-11-23 17:03:25 +08:00
|
|
|
|
return 'edit_error';
|
2020-01-01 13:17:19 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-11-25 15:29:48 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取置顶文章
|
2020-11-27 16:25:08 +08:00
|
|
|
|
* @param int $num 列表数量
|
2020-11-25 15:29:48 +08:00
|
|
|
|
* @return mixed|\think\Collection
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
2020-11-27 16:25:08 +08:00
|
|
|
|
public function getArtTop(int $num)
|
2020-11-25 15:29:48 +08:00
|
|
|
|
{
|
|
|
|
|
$artTop = Cache::get('arttop');
|
|
|
|
|
if (!$artTop) {
|
2022-11-18 10:31:44 +08:00
|
|
|
|
$artTop = $this::field('id,title,title_color,cate_id,user_id,create_time,is_top,pv,jie,upzip,has_img,has_video,has_audio')->where(['is_top' => 1, 'status' => 1])
|
|
|
|
|
->with([
|
2020-11-25 15:29:48 +08:00
|
|
|
|
'cate' => function ($query) {
|
|
|
|
|
$query->where('delete_time', 0)->field('id,catename,ename');
|
|
|
|
|
},
|
|
|
|
|
'user' => function ($query) {
|
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip');
|
|
|
|
|
}
|
2022-08-02 21:13:36 +08:00
|
|
|
|
])->withCount(['comments'])
|
|
|
|
|
->order('create_time', 'desc')
|
|
|
|
|
->limit($num)
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
2022-01-07 14:43:42 +08:00
|
|
|
|
|
2020-11-25 15:29:48 +08:00
|
|
|
|
Cache::tag('tagArtDetail')->set('arttop', $artTop, 60);
|
|
|
|
|
}
|
|
|
|
|
return $artTop;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2020-11-27 16:25:08 +08:00
|
|
|
|
* 获取首页文章列表
|
|
|
|
|
* @param int $num 列表显示数量
|
2020-11-25 15:29:48 +08:00
|
|
|
|
* @return mixed|\think\Collection
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
2020-11-27 16:25:08 +08:00
|
|
|
|
public function getArtList(int $num)
|
2020-11-25 15:29:48 +08:00
|
|
|
|
{
|
|
|
|
|
$artList = Cache::get('artlist');
|
|
|
|
|
if(!$artList){
|
2021-06-07 17:53:24 +08:00
|
|
|
|
$artList = $this::field('id,title,title_color,cate_id,user_id,create_time,is_hot,pv,jie,upzip,has_img,has_video,has_audio')
|
2020-11-25 15:29:48 +08:00
|
|
|
|
->with([
|
|
|
|
|
'cate' => function($query){
|
2021-08-03 17:33:48 +08:00
|
|
|
|
$query->where('delete_time',0)->field('id,catename,ename,detpl');
|
2020-11-25 15:29:48 +08:00
|
|
|
|
},
|
|
|
|
|
'user' => function($query){
|
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip');
|
|
|
|
|
} ])
|
2022-08-02 21:13:36 +08:00
|
|
|
|
->withCount(['comments'])
|
|
|
|
|
->where(['status'=>1,'is_top'=>0])
|
|
|
|
|
->order('create_time','desc')
|
|
|
|
|
->limit($num)
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
|
|
|
|
|
2020-11-25 15:29:48 +08:00
|
|
|
|
Cache::tag('tagArt')->set('artlist',$artList,60);
|
|
|
|
|
}
|
|
|
|
|
return $artList;
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 16:25:08 +08:00
|
|
|
|
/**
|
|
|
|
|
* 热点文章
|
|
|
|
|
* @param int $num 热点列表数量
|
|
|
|
|
* @return \think\Collection
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
|
|
|
|
public function getArtHot(int $num)
|
2020-11-25 15:29:48 +08:00
|
|
|
|
{
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$artHot = $this::field('id,cate_id,title,create_time')
|
2022-08-16 15:29:04 +08:00
|
|
|
|
->with(['cate' => function($query){
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$query->where('delete_time',0)->field('id,ename');
|
|
|
|
|
}])
|
2020-11-25 15:29:48 +08:00
|
|
|
|
->withCount('comments')
|
|
|
|
|
->where(['status'=>1,'delete_time'=>0])
|
|
|
|
|
->whereTime('create_time', 'year')
|
|
|
|
|
->order('comments_count','desc')
|
2020-11-27 16:25:08 +08:00
|
|
|
|
->limit($num)
|
2022-08-02 21:13:36 +08:00
|
|
|
|
->withCache(120)
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->select();
|
|
|
|
|
|
2020-11-25 15:29:48 +08:00
|
|
|
|
return $artHot;
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 16:25:08 +08:00
|
|
|
|
/**
|
|
|
|
|
* 获取详情
|
|
|
|
|
* @param int $id 文章id
|
|
|
|
|
* @return array|mixed|Model|null
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
2022-08-02 21:13:36 +08:00
|
|
|
|
public function getArtDetail(int $id)
|
2020-11-25 15:29:48 +08:00
|
|
|
|
{
|
|
|
|
|
$article = Cache::get('article_'.$id);
|
|
|
|
|
if(!$article){
|
|
|
|
|
//查询文章
|
2022-08-16 15:29:04 +08:00
|
|
|
|
$article = $this::field('id,title,content,status,cate_id,user_id,goods_detail_id,is_top,is_hot,is_reply,pv,jie,upzip,downloads,keywords,description,title_color,create_time,update_time')
|
|
|
|
|
->where(['status'=>1])
|
|
|
|
|
->with([
|
2020-11-25 15:29:48 +08:00
|
|
|
|
'cate' => function($query){
|
|
|
|
|
$query->where('delete_time',0)->field('id,catename,ename');
|
|
|
|
|
},
|
|
|
|
|
'user' => function($query){
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip,city')->withCount(['article','comments']);
|
2020-11-25 15:29:48 +08:00
|
|
|
|
}
|
2022-08-02 21:13:36 +08:00
|
|
|
|
])
|
|
|
|
|
->withCount(['comments'])
|
|
|
|
|
->append(['url'])
|
2022-08-16 15:29:04 +08:00
|
|
|
|
->find($id);
|
|
|
|
|
if (!is_null($article)) {
|
|
|
|
|
Cache::tag('tagArtDetail')->set('article_'.$id, $article->toArray(), 3600);
|
|
|
|
|
} else {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-25 15:29:48 +08:00
|
|
|
|
}
|
|
|
|
|
return $article;
|
|
|
|
|
}
|
2020-11-27 16:25:08 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取分类列表
|
|
|
|
|
* @param string $ename 分类英文名
|
|
|
|
|
* @param string $type all\top\hot\jie 分类类型
|
|
|
|
|
* @param int $page 页面
|
|
|
|
|
* @return mixed|\think\Paginator
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
*/
|
2022-01-07 14:45:35 +08:00
|
|
|
|
public function getCateList(string $ename, string $type, int $page = 1)
|
2020-11-27 16:25:08 +08:00
|
|
|
|
{
|
|
|
|
|
$where = [];
|
|
|
|
|
$cateId = Cate::where('ename',$ename)->value('id');
|
|
|
|
|
if($cateId){
|
|
|
|
|
$where = ['cate_id' => $cateId];
|
|
|
|
|
} else {
|
|
|
|
|
if($ename != 'all'){
|
|
|
|
|
// 抛出 HTTP 异常
|
|
|
|
|
throw new \think\exception\HttpException(404, '异常消息');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$artList = Cache::get('arts'.$ename.$type.$page);
|
|
|
|
|
if(!$artList){
|
|
|
|
|
switch ($type) {
|
|
|
|
|
//查询文章,15个分1页
|
|
|
|
|
case 'jie':
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$where['jie'] = 1;
|
2020-11-27 16:25:08 +08:00
|
|
|
|
break;
|
|
|
|
|
case 'hot':
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$where['is_hot'] = 1;
|
2020-11-27 16:25:08 +08:00
|
|
|
|
break;
|
|
|
|
|
case 'top':
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$where['is_top'] = 1;
|
2020-11-27 16:25:08 +08:00
|
|
|
|
break;
|
2021-08-03 17:33:48 +08:00
|
|
|
|
case 'wait':
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$where['jie'] = 0;
|
2021-08-03 17:33:48 +08:00
|
|
|
|
break;
|
2020-11-27 16:25:08 +08:00
|
|
|
|
default:
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$where = $where;
|
2020-11-27 16:25:08 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
2022-08-02 21:13:36 +08:00
|
|
|
|
$artList = $this::field('id,title,content,title_color,cate_id,user_id,create_time,is_top,is_hot,pv,jie,upzip,has_img,has_video,has_audio')
|
|
|
|
|
->with([
|
|
|
|
|
'cate' => function($query){
|
|
|
|
|
$query->where('delete_time',0)->field('id,catename,ename');
|
|
|
|
|
},
|
|
|
|
|
'user' => function($query){
|
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip');
|
|
|
|
|
}
|
|
|
|
|
])->withCount(['comments'])
|
|
|
|
|
->where('status',1)
|
|
|
|
|
->where($where)
|
2023-02-11 21:24:02 +08:00
|
|
|
|
->limit(15)
|
|
|
|
|
->order(['create_time'=>'desc'])
|
2022-08-02 21:13:36 +08:00
|
|
|
|
->paginate([
|
|
|
|
|
'list_rows' => 15,
|
|
|
|
|
'page' => $page
|
|
|
|
|
])->append(['url'])->toArray();
|
|
|
|
|
|
2020-11-27 16:25:08 +08:00
|
|
|
|
Cache::tag('tagArtDetail')->set('arts'.$ename.$type.$page,$artList,600);
|
|
|
|
|
}
|
|
|
|
|
return $artList;
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-02 21:13:36 +08:00
|
|
|
|
// 获取用户发帖列表
|
|
|
|
|
public function getUserArtList(int $id) {
|
|
|
|
|
$userArtList = $this::field('id,cate_id,title,create_time,pv,is_hot')
|
|
|
|
|
->with(['cate' => function($query){
|
|
|
|
|
$query->where(['delete_time'=>0,'status'=>1])->field('id,ename');
|
|
|
|
|
}])
|
|
|
|
|
->where(['user_id' => $id,'status' => 1])
|
|
|
|
|
->order(['create_time'=>'desc'])
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->cache(3600)
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
|
|
|
|
|
|
|
|
|
return $userArtList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 获取搜索文章
|
|
|
|
|
public function getSearchKeyWord(string $keywords)
|
|
|
|
|
{
|
|
|
|
|
//全局查询条件
|
|
|
|
|
$map = []; //所有的查询条件封装到数组中
|
|
|
|
|
//条件1:
|
|
|
|
|
$map[] = ['status','=',1]; //这里等号不能省略
|
|
|
|
|
|
|
|
|
|
if(!empty($keywords)){
|
|
|
|
|
//条件2
|
|
|
|
|
$map[] = ['title','like','%'.$keywords.'%'];
|
|
|
|
|
$res = Article::where($map)
|
|
|
|
|
->withCount('comments')
|
|
|
|
|
->order('create_time','desc')
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->paginate(10);
|
|
|
|
|
return $res;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-07 15:20:00 +08:00
|
|
|
|
/**
|
|
|
|
|
* 标签列表
|
|
|
|
|
*
|
|
|
|
|
* @param [type] $tagId 标签id
|
|
|
|
|
* @param [type] $limit 输出数量
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
2022-08-16 15:29:04 +08:00
|
|
|
|
public function getAllTags($tagId)
|
2022-08-02 21:13:36 +08:00
|
|
|
|
{
|
2022-08-16 15:29:04 +08:00
|
|
|
|
$allTags = $this::hasWhere('taglist',['tag_id'=>$tagId])
|
|
|
|
|
->with(['user' => function($query){
|
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip');
|
|
|
|
|
},'cate' => function($query){
|
|
|
|
|
$query->where('delete_time',0)->field('id,catename,ename');
|
|
|
|
|
}])
|
|
|
|
|
->where(['status'=>1])
|
|
|
|
|
->order('pv desc')
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
|
|
|
|
|
|
|
|
|
return $allTags;
|
2022-08-02 21:13:36 +08:00
|
|
|
|
}
|
|
|
|
|
|
2022-09-07 15:20:00 +08:00
|
|
|
|
/**
|
|
|
|
|
* 相关文章(标签)
|
|
|
|
|
* 相同标签文章,不包含自己
|
|
|
|
|
* @param [type] $tagId
|
|
|
|
|
* @param [type] $limit
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function getRelationTags($tagId,$id,$limit)
|
|
|
|
|
{
|
|
|
|
|
$allTags = $this::hasWhere('taglist',['tag_id'=>$tagId])
|
|
|
|
|
->with(['user' => function($query){
|
|
|
|
|
$query->field('id,name,nickname,user_img,area_id,vip');
|
|
|
|
|
},'cate' => function($query){
|
|
|
|
|
$query->where('delete_time',0)->field('id,catename,ename');
|
|
|
|
|
}])
|
|
|
|
|
->where(['status'=>1])
|
2022-09-07 15:21:56 +08:00
|
|
|
|
// ->where('article.id', '<>', $id)
|
2022-09-07 15:20:00 +08:00
|
|
|
|
->order('pv desc')
|
|
|
|
|
->limit($limit)
|
|
|
|
|
->append(['url'])
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
|
|
|
|
|
|
|
|
|
return $allTags;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 上下文
|
|
|
|
|
*
|
|
|
|
|
* @param [type] $id 当前文章ID
|
|
|
|
|
* @param [type] $cid 当前分类ID
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public function getPrevNextArticle($id,$cid)
|
|
|
|
|
{
|
|
|
|
|
//上一篇
|
|
|
|
|
$previous = $this::field('id,title,cate_id')
|
|
|
|
|
->where([
|
|
|
|
|
['id', '<', $id],
|
|
|
|
|
['cate_id', '=', $cid],
|
|
|
|
|
['status', '=',1]
|
|
|
|
|
])->order('id desc')->limit(1)->append(['url'])->select()->toArray();
|
|
|
|
|
|
|
|
|
|
//下一篇
|
|
|
|
|
$next = $this::field('id,title,cate_id')
|
|
|
|
|
->where([
|
|
|
|
|
['id', '>', $id],
|
|
|
|
|
['cate_id', '=', $cid],
|
|
|
|
|
['status', '=',1]
|
|
|
|
|
])->limit(1)->append(['url'])->select()->toArray();
|
|
|
|
|
|
|
|
|
|
return ['previous' => $previous, 'next' => $next];
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-02 21:13:36 +08:00
|
|
|
|
// 获取url
|
|
|
|
|
public function getUrlAttr($value,$data)
|
|
|
|
|
{
|
|
|
|
|
if(config('taoler.url_rewrite.article_as') == '<ename>/') {
|
|
|
|
|
$cate = Cate::field('id,ename')->find($data['cate_id']);
|
|
|
|
|
return (string) url('article_detail',['id' => $data['id'],'ename' => $cate->ename]);
|
|
|
|
|
} else {
|
|
|
|
|
return (string) url('article_detail',['id' => $data['id']]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-27 16:25:08 +08:00
|
|
|
|
|
2020-01-01 13:17:19 +08:00
|
|
|
|
}
|