Spring Boot音乐服务器项目-查询音乐模块

一、项目架构概览

该音乐播放服务器采用经典的MVC分层架构,核心模块包括:

  1. 实体层:定义数据模型
  2. Mapper层:数据库操作接口
  3. Controller层:HTTP请求处理
  4. 工具层:加密、响应封装等辅助功能

项目核心功能包括用户认证、音乐上传/播放、收藏管理等,下面按分层结构详解实现逻辑。


二、接口设计
  1. ⽀持模糊查询
  2. ⽀持传⼊参数为空
请求示例
复制代码
{
  "method": "get",
  "url": "/music/findmusic",
  "data": {
    "musicName": musicName
  }
}
响应示例
  1. 未给 musicName 传参时

    {
    "status": 0,
    "message": "查询到了歌曲的信息",
    "data": [
    {
    "id": 19,
    "title": "银河与星斗(女生版)",
    "singer": "gaobo",
    "url": "/music/get?path=银河与星斗(女生版)",
    "time": "2022-03-28",
    "userid": 3
    },
    {
    "id": 20,
    "title": "liu",
    "singer": "bit",
    "url": "/music/get?path=liu",
    "time": "2022-03-28",
    "userid": 3
    }
    ]
    }

  2. 给 musicName 传参时

    {
    "status": 0,
    "message": "查询到了歌曲的信息",
    "data": [
    {
    "id": 19,
    "title": "银河与星斗(女生版)",
    "singer": "gaobo",
    "url": "/music/get?path=银河与星斗(女生版)",
    "time": "2022-03-28",
    "userid": 3
    }
    ]
    }


三、Mapper层实现

使用MyBatis实现数据库操作,核心接口:

1. 查询功能Mapper
复制代码
    /**
     *根据歌曲名字,查询⾳乐
     * @param name
     * @return
     */

    List<Music> findMusicByMusicName(String name);

    /**
     查询所有的⾳乐
     @return
     */
    List<Music> findMusic();

XML映射

复制代码
    <select id="findMusicByMusicName"
            resultType="com.example.musicplayer.model.Music">
            select * from music where title like concat('%',#{musicName},'%')
    </select>
    <select id="findMusic" resultType="com.example.musicserver.model.Music">
            select * from music
    </select>

四、MusicController类新增⽅法

处理HTTP请求并调用Mapper操作:

音乐查询接口
复制代码
/**
     根据musicName查询音乐
     @param musicName
     @return
     */
    @RequestMapping("/findmusic")
    public ResponseBodyMessage<List<Music>> findMusic(@RequestParam(required=false)String musicName) {
        List<Music> musicList = null;
        if(musicName != null) {
            musicList = musicMapper.findMusicByMusicName(musicName);
        }else {
            //默认查询全部的⾳乐
            musicList = musicMapper.findMusic();
        }
        return new ResponseBodyMessage<>(0,"查询到了歌曲的信息",musicList);
    }

测试工作

代码仓库:查询音乐接口开发 7.22音乐服务器 - Gitee.com

相关推荐
space62123271 天前
在SpringBoot项目中集成MongoDB
spring boot·后端·mongodb
珠海西格电力科技1 天前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市
释怀不想释怀1 天前
Linux环境变量
linux·运维·服务器
zzzsde1 天前
【Linux】进程(4):进程优先级&&调度队列
linux·运维·服务器
Tony Bai1 天前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
寻找奶酪的mouse1 天前
30岁技术人对职业和生活的思考
前端·后端·年终总结
qq_297574671 天前
Linux 服务器 Java 开发环境搭建保姆级教程
java·linux·服务器
梦想很大很大1 天前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
金牌归来发现妻女流落街头1 天前
【从SpringBoot到SpringCloud】
java·spring boot·spring cloud
毅炼1 天前
Java 基础常见问题总结(4)
java·后端