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

相关推荐
自珍JAVA4 小时前
访问者模式:让你的代码优雅地“拜访”对象结构
后端
ZFSS5 小时前
Localization Translate API 集成与使用指南
java·服务器·数据库·人工智能·mysql·ai编程
毅航6 小时前
AI 浪潮下,会用工具不等于具备能力
后端·程序员·ai编程
索木木7 小时前
NCCL SHARP 和 TREE算法
java·服务器·算法
比特森林探险记7 小时前
go 语言中的context 解读和用法
开发语言·后端·golang
刀法如飞7 小时前
《道德经》简单解说版-第 2 章:天下皆知美之为美
前端·后端·面试
Bert.Cai8 小时前
Linux let命令详解
linux·运维·服务器
晚风予卿云月8 小时前
【Linux】环境变量概念、作用、配置与修改详解
linux·运维·服务器·环境变量
benjiangliu8 小时前
LINUX系统-17-EXT系列文件系统(二)
linux·运维·服务器
杨云龙UP8 小时前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache