428 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			428 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| /**
 | ||
|  * 商业使用授权协议
 | ||
|  * 
 | ||
|  * Copyright (c) 2025 [云泽网]. 保留所有权利.
 | ||
|  * 
 | ||
|  * 本软件仅供评估使用。任何商业用途必须获得书面授权许可。
 | ||
|  * 未经授权商业使用本软件属于侵权行为,将承担法律责任。
 | ||
|  * 
 | ||
|  * 授权购买请联系: 357099073@qq.com
 | ||
|  * 官方网站: https://www.yunzer.cn
 | ||
|  * 
 | ||
|  * 评估用户须知:
 | ||
|  * 1. 禁止移除版权声明
 | ||
|  * 2. 禁止用于生产环境
 | ||
|  * 3. 禁止转售或分发
 | ||
|  */
 | ||
| 
 | ||
| /**
 | ||
|  *	后台管理系统-首页
 | ||
|  */
 | ||
| namespace app\index\controller;
 | ||
| use app\index\controller\BaseController;
 | ||
| use think\facade\Db;
 | ||
| use think\facade\View;
 | ||
| use think\facade\Env;
 | ||
| use think\facade\Config;
 | ||
| use app\index\model\Banner;
 | ||
| use app\index\model\Resources\ResourcesCategory;
 | ||
| use app\index\model\Articles\ArticlesCategory;
 | ||
| use app\index\model\Resources\Resources;
 | ||
| use app\index\model\Articles\Articles;
 | ||
| use app\index\model\MailConfig;
 | ||
| use \think\facade\Filesystem;
 | ||
| use app\index\model\Attachments;
 | ||
| 
 | ||
| 
 | ||
| class IndexController extends BaseController
 | ||
| {
 | ||
|     /**
 | ||
|      * 首页
 | ||
|      */
 | ||
|     public function index()
 | ||
|     {
 | ||
|         // 获取banner列表
 | ||
|         $bannerList = Banner::where('delete_time', null)
 | ||
|             ->order('sort DESC, id DESC')
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         View::assign('bannerList', $bannerList);
 | ||
|         return View::fetch();
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取站点资讯列表
 | ||
|      */
 | ||
|     public function siteNewslist()
 | ||
|     {
 | ||
|         // 获取站点资讯分类(顶级分类id为1的子分类)
 | ||
|         $categories = ArticlesCategory::where('cid', 1)
 | ||
|             ->where('delete_time', null)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         $articles = [];
 | ||
|         $categoryData = [];
 | ||
| 
 | ||
|         // 提取分类名称和ID用于前端tab显示
 | ||
|         foreach ($categories as $category) {
 | ||
|             $categoryData[] = [
 | ||
|                 'id' => $category['id'],
 | ||
|                 'name' => $category['name']
 | ||
|             ];
 | ||
| 
 | ||
|             // 获取该分类下的文章,限制4条
 | ||
|             $articles = Articles::where('cate', $category['id'])
 | ||
|                 ->where('delete_time', null)
 | ||
|                 ->where('status', 2)
 | ||
|                 ->order('id', 'desc')
 | ||
|                 ->field('id, cate, title, image, author, publishdate, views')
 | ||
|                 ->limit(4)
 | ||
|                 ->select()
 | ||
|                 ->toArray();
 | ||
| 
 | ||
|         }
 | ||
| 
 | ||
|         return json([
 | ||
|             'code' => 1,
 | ||
|             'msg' => '获取成功',
 | ||
|             'articles' => $articles,
 | ||
|             'categories' => $categoryData
 | ||
|         ]);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取技术文章列表
 | ||
|      */
 | ||
|     public function technicalArticleslist()
 | ||
|     {
 | ||
|         // 获取技术文章分类(顶级分类id为3的子分类)
 | ||
|         $categories = ArticlesCategory::where('cid', 3)
 | ||
|             ->where('delete_time', null)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         // 组装分类数据,方便后续查找
 | ||
|         $categoryData = [];
 | ||
|         $categoryImageMap = [];
 | ||
|         $articlesByCategory = [];
 | ||
| 
 | ||
|         foreach ($categories as $category) {
 | ||
|             $categoryData[] = [
 | ||
|                 'id' => $category['id'],
 | ||
|                 'name' => $category['name']
 | ||
|             ];
 | ||
|             $categoryImageMap[$category['id']] = $category['image'] ?? '';
 | ||
| 
 | ||
|             // 获取每个分类下的文章,限制12条
 | ||
|             $articles = Articles::where('cate', $category['id'])
 | ||
|                 ->where('delete_time', null)
 | ||
|                 ->where('status', 2)
 | ||
|                 ->order('id', 'desc')
 | ||
|                 ->field('id, cate, title, image, author, publishdate, views')
 | ||
|                 ->limit(12)
 | ||
|                 ->select()
 | ||
|                 ->toArray();
 | ||
| 
 | ||
|             // 替换image为空的文章
 | ||
|             foreach ($articles as &$article) {
 | ||
|                 if (empty($article['image']) && !empty($categoryImageMap[$article['cate']])) {
 | ||
|                     $article['image'] = $categoryImageMap[$article['cate']];
 | ||
|                 }
 | ||
|             }
 | ||
|             unset($article);
 | ||
| 
 | ||
|             $articlesByCategory[$category['id']] = $articles;
 | ||
|         }
 | ||
| 
 | ||
|         return json([
 | ||
|             'code' => 1,
 | ||
|             'msg' => '获取成功',
 | ||
|             'articles' => $articlesByCategory,
 | ||
|             'categories' => $categoryData
 | ||
|         ]);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取banner列表
 | ||
|      */
 | ||
|     public function bannerlist()
 | ||
|     {
 | ||
|         // 获取启用状态的banner列表,按排序倒序
 | ||
|         $bannerList = Banner::where('delete_time', null)
 | ||
|             ->order('sort DESC, id DESC')
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         return json(['code' => 1, 'msg' => '获取成功', 'banner' => $bannerList]);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取资源下载列表
 | ||
|      */
 | ||
|     public function resourcesList()
 | ||
|     {
 | ||
|         // 获取资源分类(顶级分类id为2的子分类)
 | ||
|         $categories = ResourcesCategory::where('cid', 2)
 | ||
|             ->where('delete_time', null)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         // 组装分类数据
 | ||
|         $categoryData = [];
 | ||
|         $categoryImageMap = [];
 | ||
|         $resourcesByCategory = [];
 | ||
| 
 | ||
|         foreach ($categories as $category) {
 | ||
|             $categoryData[] = [
 | ||
|                 'id' => $category['id'],
 | ||
|                 'name' => $category['name']
 | ||
|             ];
 | ||
|             $categoryImageMap[$category['id']] = $category['image'] ?? '';
 | ||
| 
 | ||
|             // 获取每个分类下的资源,限制8条
 | ||
|             $resources = Resources::where('cate', $category['id'])
 | ||
|                 ->where('delete_time', null)
 | ||
|                 ->where('status', 1)
 | ||
|                 ->order('id', 'desc')
 | ||
|                 ->field('id, cate, title, desc, downloads, create_time, icon, views, uploader')
 | ||
|                 ->limit(8)
 | ||
|                 ->select()
 | ||
|                 ->toArray();
 | ||
| 
 | ||
|             // 替换thumbnail为空的资源
 | ||
|             foreach ($resources as &$resource) {
 | ||
|                 if (empty($resource['thumbnail']) && !empty($categoryImageMap[$resource['cate']])) {
 | ||
|                     $resource['thumbnail'] = $categoryImageMap[$resource['cate']];
 | ||
|                 }
 | ||
|             }
 | ||
|             unset($resource);
 | ||
| 
 | ||
|             $resourcesByCategory[$category['id']] = $resources;
 | ||
|         }
 | ||
| 
 | ||
|         // 合并所有分类的资源
 | ||
|         $allResources = [];
 | ||
|         foreach ($resourcesByCategory as $resources) {
 | ||
|             $allResources = array_merge($allResources, $resources);
 | ||
|         }
 | ||
| 
 | ||
|         // 按上传时间排序
 | ||
|         usort($allResources, function ($a, $b) {
 | ||
|             return $b['create_time'] - $a['create_time'];
 | ||
|         });
 | ||
| 
 | ||
|         // 只取最新的8条
 | ||
|         $allResources = array_slice($allResources, 0, 8);
 | ||
| 
 | ||
|         return json([
 | ||
|             'code' => 1,
 | ||
|             'msg' => '获取成功',
 | ||
|             'resources' => $allResources,
 | ||
|             'categories' => $categoryData
 | ||
|         ]);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取程序下载列表
 | ||
|      */
 | ||
|     public function programList()
 | ||
|     {
 | ||
|         // 获取程序分类(顶级分类id为4的子分类)
 | ||
|         $categories = ResourcesCategory::where('cid', 1)
 | ||
|             ->where('delete_time', null)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         // 组装分类数据
 | ||
|         $categoryData = [];
 | ||
|         $categoryImageMap = [];
 | ||
|         $programsByCategory = [];
 | ||
| 
 | ||
|         foreach ($categories as $category) {
 | ||
|             $categoryData[] = [
 | ||
|                 'id' => $category['id'],
 | ||
|                 'name' => $category['name']
 | ||
|             ];
 | ||
|             $categoryImageMap[$category['id']] = $category['image'] ?? '';
 | ||
| 
 | ||
|             // 获取每个分类下的程序,限制8条
 | ||
|             $programs = Resources::where('cate', $category['id'])
 | ||
|                 ->where('delete_time', null)
 | ||
|                 ->where('status', 1)
 | ||
|                 ->order('id', 'desc')
 | ||
|                 ->field('id, cate, title, desc, downloads, create_time, icon, views, uploader')
 | ||
|                 ->limit(8)
 | ||
|                 ->select()
 | ||
|                 ->toArray();
 | ||
| 
 | ||
|             // 替换thumbnail为空的程序
 | ||
|             foreach ($programs as &$program) {
 | ||
|                 if (empty($program['thumbnail']) && !empty($categoryImageMap[$program['cate']])) {
 | ||
|                     $program['thumbnail'] = $categoryImageMap[$program['cate']];
 | ||
|                 }
 | ||
|             }
 | ||
|             unset($program);
 | ||
| 
 | ||
|             $programsByCategory[$category['id']] = $programs;
 | ||
|         }
 | ||
| 
 | ||
|         // 合并所有分类的程序
 | ||
|         $allPrograms = [];
 | ||
|         foreach ($programsByCategory as $programs) {
 | ||
|             $allPrograms = array_merge($allPrograms, $programs);
 | ||
|         }
 | ||
| 
 | ||
|         // 按上传时间排序
 | ||
|         usort($allPrograms, function ($a, $b) {
 | ||
|             return $b['create_time'] - $a['create_time'];
 | ||
|         });
 | ||
| 
 | ||
|         // 只取最新的8条
 | ||
|         $allPrograms = array_slice($allPrograms, 0, 8);
 | ||
| 
 | ||
|         return json([
 | ||
|             'code' => 1,
 | ||
|             'msg' => '获取成功',
 | ||
|             'programs' => $allPrograms,
 | ||
|             'categories' => $categoryData
 | ||
|         ]);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * 获取游戏下载列表
 | ||
|      */
 | ||
|     public function gameList()
 | ||
|     {
 | ||
|         // 获取游戏分类(顶级分类id为8的子分类)
 | ||
|         $categories = ResourcesCategory::where('cid', 8)
 | ||
|             ->where('delete_time', null)
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
| 
 | ||
|         // 组装分类数据
 | ||
|         $categoryData = [];
 | ||
|         $categoryImageMap = [];
 | ||
|         $programsByCategory = [];
 | ||
| 
 | ||
|         foreach ($categories as $category) {
 | ||
|             $categoryData[] = [
 | ||
|                 'id' => $category['id'],
 | ||
|                 'name' => $category['name'],
 | ||
|                 'image' => $category['image'] ?? ''
 | ||
|             ];
 | ||
| 
 | ||
|             // 获取每个分类下的游戏,限制8条
 | ||
|             $programs = Resources::where('cate', $category['id'])
 | ||
|                 ->where('delete_time', null)
 | ||
|                 ->where('status', 1)
 | ||
|                 ->order('id', 'desc')
 | ||
|                 ->field('id, cate, title, desc, downloads, create_time, icon, views, uploader, number, url, code')
 | ||
|                 ->limit(8)
 | ||
|                 ->select()
 | ||
|                 ->toArray();
 | ||
| 
 | ||
|             // 处理游戏数据
 | ||
|             foreach ($programs as &$program) {
 | ||
|                 // 如果没有图标,使用分类图片
 | ||
|                 if (empty($program['icon']) && !empty($category['image'])) {
 | ||
|                     $program['icon'] = $category['image'];
 | ||
|                 }
 | ||
|                 // 格式化时间
 | ||
|                 $program['create_time'] = date('Y-m-d H:i:s', $program['create_time']);
 | ||
|             }
 | ||
|             unset($program);
 | ||
| 
 | ||
|             $programsByCategory[$category['id']] = $programs;
 | ||
|         }
 | ||
| 
 | ||
|         // 合并所有分类的游戏
 | ||
|         $allPrograms = [];
 | ||
|         foreach ($programsByCategory as $programs) {
 | ||
|             $allPrograms = array_merge($allPrograms, $programs);
 | ||
|         }
 | ||
| 
 | ||
|         // 按上传时间排序
 | ||
|         usort($allPrograms, function ($a, $b) {
 | ||
|             return strtotime($b['create_time']) - strtotime($a['create_time']);
 | ||
|         });
 | ||
| 
 | ||
|         // 只取最新的8条
 | ||
|         $allPrograms = array_slice($allPrograms, 0, 8);
 | ||
| 
 | ||
|         return json([
 | ||
|             'code' => 0,
 | ||
|             'msg' => '获取成功',
 | ||
|             'data' => [
 | ||
|                 'games' => $allPrograms,
 | ||
|                 'categories' => $categoryData
 | ||
|             ]
 | ||
|         ]);
 | ||
|     }
 | ||
| 
 | ||
|     //保存附件信息到数据库
 | ||
|     private function saveAttachment($name, $type, $size, $src)
 | ||
|     {
 | ||
|         $data = [
 | ||
|             'name' => $name,
 | ||
|             'type' => $type,
 | ||
|             'size' => $size,
 | ||
|             'src' => $src,
 | ||
|             'create_time' => time(),
 | ||
|             'update_time' => time()
 | ||
|         ];
 | ||
|         return Attachments::insertGetId($data);
 | ||
|     }
 | ||
| 
 | ||
|     //上传图片接口
 | ||
|     public function update_imgs()
 | ||
|     {
 | ||
|         // 获取上传的文件
 | ||
|         $file = request()->file();
 | ||
|         $files = request()->file('file');
 | ||
| 
 | ||
|         // 检查是否有文件上传
 | ||
|         if (empty($file)) {
 | ||
|             return json(['code' => 1, 'msg' => '没有文件上传']);
 | ||
|         }
 | ||
| 
 | ||
|         try {
 | ||
|             // 验证上传的文件
 | ||
|             validate([
 | ||
|                 'image' => 'filesize:51200|fileExt:jpg,png,gif,jpeg,webp'
 | ||
|             ])->check($file);
 | ||
| 
 | ||
|             // 存储文件到public磁盘的uploads目录
 | ||
|             $info = Filesystem::disk('public')->putFile('uploads', $files);
 | ||
| 
 | ||
|             // 处理文件路径,统一使用正斜杠
 | ||
|             $info = str_replace("\\", "/", $info);
 | ||
|             $img = '/storage/' . $info;
 | ||
| 
 | ||
|             // 保存附件信息
 | ||
|             $fileName = $files->getOriginalName();
 | ||
|             $fileSize = $files->getSize();
 | ||
|             $attachmentId = $this->saveAttachment($fileName, 1, $fileSize, $img); // 1: 图片
 | ||
| 
 | ||
|             // 返回成功信息
 | ||
|             return json([
 | ||
|                 'code' => 0,
 | ||
|                 'data' => [
 | ||
|                     'url' => $img
 | ||
|                 ],
 | ||
|                 'msg' => '上传成功'
 | ||
|             ]);
 | ||
| 
 | ||
|         } catch (\think\exception\ValidateException $e) {
 | ||
|             // 捕获验证异常并返回错误信息
 | ||
|             return json(['code' => 1, 'msg' => $e->getMessage()]);
 | ||
|         } catch (\Exception $e) {
 | ||
|             // 捕获其他异常
 | ||
|             return json(['code' => 1, 'msg' => '上传失败:' . $e->getMessage()]);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| }
 |