实战--11

一、分类模块(Category)接口

1. 全量分类查询 findAllDetail()

java

运行

复制代码
@Override
public Result findAllDetail() {
    LambdaQueryWrapper<Category> queryWrapper = new LambdaQueryWrapper<>();
    List<Category> categories = categoryMapper.selectList(queryWrapper);
    return Result.success(copyList(categories));
}
  • 逻辑:无筛选条件查询全部分类,调用copyList批量转 VO 后返回
  • 特点:返回所有分类数据,常用于前端分类下拉框、侧边栏等场景

2. 分类详情查询 categoryDetailById()

java

运行

复制代码
@Override
public Result categoryDetailById(Long id) {
    Category category = categoryMapper.selectById(id);
    return Result.success(copy(category));
}
  • 逻辑:根据 ID 查询单个分类详情,调用copy方法转为 VO
  • 关键:copy方法实现了Long 雪花 ID 转 String,避免前端精度丢失

3. 核心 VO 转换方法

java

运行

复制代码
public CategoryVo copy(Category category) {
    CategoryVo categoryVo = new CategoryVo();
    BeanUtils.copyProperties(category, categoryVo);
    // 关键处理:将Long类型的ID转为String,适配前端JS
    categoryVo.setId(String.valueOf(category.getId()));
    return categoryVo;
}

public List<CategoryVo> copyList(List<Category> categoryList) {
    List<CategoryVo> categoryVoList = new ArrayList<>();
    for (Category category : categoryList) {
        categoryVoList.add(copy(category));
    }
    return categoryVoList;
}
  • BeanUtils.copyProperties:实现同名属性快速拷贝
  • String.valueOf(category.getId()):核心处理,解决前端 JS 对大整数精度丢失的问题

二、标签模块(Tag)接口

1. 全量标签查询 findAllDetail()

java

运行

复制代码
@Override
public Result findAllDetail() {
    LambdaQueryWrapper<Tag> queryWrapper = new LambdaQueryWrapper<>();
    List<Tag> tags = this.tagMapper.selectList(queryWrapper);
    return Result.success(copyList(tags));
}
  • 逻辑与分类接口完全一致,查询全量标签后转 VO 返回

2. 标签详情查询 findDetailById()

java

运行

复制代码
@Override
public Result findDetailById(Long id) {
    Tag tag = tagMapper.selectById(id);
    return Result.success(copy(tag));
}
  • 逻辑:根据 ID 查询单个标签详情,转 VO 后返回
  • 注:代码结构与分类详情接口高度一致,体现了代码的复用性设计

三、文章列表接口 listArticle()(分页 + 多条件 + Redis 浏览量)

java

运行

复制代码
@Override
public Result listArticle(PageParams pageParams) {
    // 1. 构建分页对象
    Page<Article> page = new Page<>(pageParams.getPage(), pageParams.getPageSize());
    
    // 2. 多条件分页查询文章(分类、标签、年份、月份)
    IPage<Article> articleIPage = articleMapper.listArticle(
        page,
        pageParams.getCategoryId(),
        pageParams.getTagId(),
        pageParams.getYear(),
        pageParams.getMonth());
    List<Article> records = articleIPage.getRecords();
    
    // 3. 从Redis补充实时浏览量(替代DB数据)
    for (Article record : records) {
        String viewCount = (String) redisTemplate.opsForHash()
            .get("view_count", String.valueOf(record.getId()));
        if (viewCount != null) {
            record.setViewCounts(Integer.parseInt(viewCount));
        }
    }
    
    // 4. 转VO并返回
    return Result.success(copyList(records, isTag: true, isAuthor: true));
}

核心亮点拆解

  1. MyBatis-Plus 分页Page对象封装当前页、页大小,IPage接收分页结果,自动处理总条数、分页数据
  2. 多条件查询:支持按分类 ID、标签 ID、发布年份 / 月份筛选文章
  3. Redis 浏览量补充
    • 从 Redis 的view_count Hash 结构中获取实时浏览量
    • 覆盖 DB 中的旧浏览量数据,保证前端展示的是最新计数
  4. VO 扩展转换copyList额外传入isTagisAuthor参数,自动封装标签、作者信息,减少前端请求
相关推荐
星恒随风13 天前
C++ string 类详解:常用接口、OJ 场景与模拟实现中的深浅拷贝
开发语言·c++·笔记·学习·状态模式
colofullove15 天前
实时游玩页与 WebSocket 状态管理实现
websocket·网络协议·状态模式
夏天测15 天前
业务逻辑漏洞实战:篡改响应包绕过登录,直入后台管理系统
渗透测试·状态模式·业务逻辑漏洞·web 安全·响应包篡改
可乐ea16 天前
【Spring Boot + MyBatis|第7篇】JWT 登录认证与拦截器实现
java·spring boot·后端·mybatis·状态模式
前端不太难16 天前
GPU 集群调度架构解析
架构·状态模式
ShiJiuD66688899916 天前
外卖项目笔记总结上 (后端板块)
状态模式
前端不太难16 天前
当 AI 接管 Workspace:鸿蒙 PC Agent 架构设计实践
人工智能·状态模式·harmonyos
Maimai1080817 天前
Web3 前端实时通信如何落地:从 SSE 订阅到行情、订单与账户状态更新
前端·javascript·react.js·前端框架·web3·状态模式
不吃青椒!18 天前
LangGraph 流式事件处理:从实战到体系
ai·langchain·状态模式
前端不太难18 天前
鸿蒙游戏世界模型:实现原理 + Demo实现
游戏·状态模式·harmonyos