增加搜索接口

This commit is contained in:
李志强 2025-12-26 17:03:57 +08:00
parent 9edafa66e7
commit 3519525af8
3 changed files with 137 additions and 5 deletions

View File

@ -375,12 +375,14 @@ class ArticlesController extends BaseController
// 查询相关文章同分类排除当前文章按发布时间倒序取5个 // 查询相关文章同分类排除当前文章按发布时间倒序取5个
$relatedArticles = Articles::where([ $relatedArticles = Articles::where([
['id', '<>', $id], ['a.id', '<>', $id],
['cate', '=', $currentCateId], ['a.cate', '=', $currentCateId],
['delete_time', '=', null], ['a.delete_time', '=', null],
['status', '=', 2] ['a.status', '=', 2]
]) ])
->field('id,title,image,views,likes,publishdate') ->field('a.id,a.title,IF(a.image IS NULL OR a.image = \'\', ac.image, a.image) as image,a.views,a.likes,a.publishdate')
->alias('a')
->join('articles_category ac', 'a.cate = ac.id', 'LEFT')
->order('publishdate', 'desc') ->order('publishdate', 'desc')
->limit(5) ->limit(5)
->select(); ->select();

View File

@ -125,4 +125,131 @@ class SearchController extends BaseController
return view('index', $viewData); return view('index', $viewData);
} }
// JSON API搜索接口
public function apiSearch()
{
try {
$keyword = input('keyword', '');
$type = input('type', 'articles'); // 搜索类型articles-文章resources-资源
$page = input('page/d', 1);
$limit = input('limit/d', 10);
if (empty($keyword)) {
return json([
'code' => 1,
'msg' => '请输入搜索关键词'
]);
}
if (empty($type)) {
return json([
'code' => 1,
'msg' => '请选择搜索类型'
]);
}
// 根据类型选择对应的表和分类表
if ($type == 'articles') {
$model = new Articles();
$categoryModel = new ArticlesCategory();
$status = 2; // 文章状态为2
$fields = 'id, title, cate, image, author, FROM_UNIXTIME(create_time, "%Y-%m-%d") as publishdate';
} else if ($type == 'resources') {
$model = new Resources();
$categoryModel = new ResourcesCategory();
$status = 1; // 资源状态为1
$fields = 'id, title, cate, icon, uploader, FROM_UNIXTIME(create_time, "%Y-%m-%d") as publishdate';
} else {
return json([
'code' => 1,
'msg' => '无效的搜索类型'
]);
}
// 搜索内容
$items = $model->where('title', 'like', "%{$keyword}%")
->where('status', $status)
->field($fields)
->order('create_time desc')
->page($page, $limit)
->select();
// 获取总数
$count = $model->where('title', 'like', "%{$keyword}%")
->where('status', $status)
->count();
// 获取分类名称和图片
$resultItems = [];
foreach ($items as $item) {
$itemData = $item->toArray();
if ($type == 'articles') {
$category = $categoryModel->where('id', $itemData['cate'])
->field('id, name, image')
->find();
$itemData['category'] = $category ? $category->toArray() : ['id' => 0, 'name' => '未分类', 'image' => ''];
// 如果文章的图片为空,使用分类的图片
if (empty($itemData['image'])) {
$itemData['image'] = $itemData['category']['image'];
}
if (empty($itemData['image'])) {
$itemData['image'] = '/static/images/default.jpg';
}
$itemData['detail_url'] = url('articles/detail', ['id' => $itemData['id']], true, true);
} else {
$category = $categoryModel->where('id', $itemData['cate'])
->field('id, name, icon, cid')
->find();
$itemData['category'] = $category ? $category->toArray() : ['id' => 0, 'name' => '未分类', 'icon' => '', 'cid' => 0];
// 如果资源的图片为空,使用分类的图片
if (empty($itemData['icon'])) {
$itemData['icon'] = $itemData['category']['icon'];
}
if (empty($itemData['icon'])) {
$itemData['icon'] = '/static/images/default.jpg';
}
// 根据分类cid判断资源类型
if ($itemData['category']['cid'] == 8) {
$itemData['detail_url'] = url('game/detail', ['id' => $itemData['id']], true, true);
} else {
$itemData['detail_url'] = url('program/detail', ['id' => $itemData['id']], true, true);
}
}
$resultItems[] = $itemData;
}
// 计算分页信息
$totalPages = ceil($count / $limit);
return json([
'code' => 0,
'msg' => '搜索成功',
'data' => [
'keyword' => $keyword,
'type' => $type,
'items' => $resultItems,
'total' => $count,
'page' => $page,
'limit' => $limit,
'total_pages' => $totalPages,
'has_more' => $page < $totalPages
]
]);
} catch (\Exception $e) {
return json([
'code' => 1,
'msg' => '搜索失败:' . $e->getMessage()
]);
}
}
} }

View File

@ -47,4 +47,7 @@ Route::group('api', function () {
Route::post('admin/logout', 'api/Admin/logout'); Route::post('admin/logout', 'api/Admin/logout');
Route::post('admin/change-password', 'api/Admin/changePassword'); Route::post('admin/change-password', 'api/Admin/changePassword');
Route::get('admin/menus', 'api/Admin/menus'); Route::get('admin/menus', 'api/Admin/menus');
// 搜索接口
Route::get('search', 'index/Search/apiSearch');
})->middleware(\app\middleware\Cors::class); })->middleware(\app\middleware\Cors::class);