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

相关推荐
毕业设计制作和分享2 小时前
springboot150基于springboot的贸易行业crm系统
java·vue.js·spring boot·后端·毕业设计·mybatis
编啊编程啊程4 小时前
【011】宠物共享平台
spring boot·log4j·maven·dubbo·宠物
你的人类朋友6 小时前
【Node】认识multer库
前端·javascript·后端
lang201509288 小时前
Spring Boot 官方文档精解:构建与依赖管理
java·spring boot·后端
Andya_net8 小时前
网络安全 | 深入了解 X.509 证书及其应用
服务器·安全·web安全
why技术9 小时前
从18w到1600w播放量,我的一点思考。
java·前端·后端
间彧9 小时前
Redis Cluster vs Sentinel模式区别
后端
间彧9 小时前
🛡️ 构建高可用缓存架构:Redis集群与Caffeine多级缓存实战
后端
间彧9 小时前
构建本地缓存(如Caffeine)+ 分布式缓存(如Redis集群)的二级缓存架构
后端
qq_1838028710 小时前
Linux内核idr数据结构使用
linux·运维·服务器