Spring Boot音乐服务器项目-删除音乐模块
Java音乐播放服务器:删除音乐功能设计与实现详解
在音乐播放服务器中,删除音乐功能分为单个删除和批量删除两个核心模块。
接口设计预期设计:
请求: {post, /music/delete, id }
响应: {"status":0,"message":"删除成功!", "data":true }
我们已经在前面定义了Music的实体层(Model)
接下来我们就定义出两个接口
一、Mapper层(数据访问层)
1. 接口声明(MusicMapper.java)<查到了才能删,查是删的基础>
/**根据ID删除⾳乐@param musicId@return*/int deleteMusicById(int musicId);/**根据ID查询⾳乐@param id@return*/Music findMusicById(int id);
2. XML映射(MusicMapper.xml)
</insert><delete id="deleteMusicById" parameterType="java.lang.Integer">delete from music where id = #{id}</delete><select id="findMusicById" resultType="com.example.musicplayer.model.Music">select * from music where id = #{id}</select>
二、Controller层(API设计)
1. 单个音乐删除(/music/delete
)
@RequestMapping("/delete")public ResponseBodyMessage<Boolean> deleteMusicById(@RequestParam String id){int musicId = Integer.parseInt(id);Music music = musicMapper.findMusicById(musicId);if (music == null)return new ResponseBodyMessage<>(-1,"没有你所需要的音乐",false);int ret = musicMapper.deleteMusicById(musicId);if (ret == 1) {int index = music.getUrl().lastIndexOf("=");String filename = music.getUrl().substring(index + 1);File file = new File(SAVE_PATH + "/" + filename + ".mp3");System.out.println("路径为:" + file.getPath());if (file.delete()) {return new ResponseBodyMessage<>(0, "删除音乐成功", true);} else {return new ResponseBodyMessage<>(1, "删除音乐失败", false);}}else {return new ResponseBodyMessage<>(-1,"在数据库中删除音乐失败",false);}}
在我习惯看来,我是不太习惯在controller层写下这么多逻辑,我认为这里的绝大部分代码应该是放在service层去实现的,但是这个项目体量接口比较少,所以我就都放在controller层一并实现了。
写完后我们跑起来运行一遍
2. 批量删除(/music/deleteSel
)
<实体层、mapper层对批量处理都是适用的,所以只需要在这里处理一个批量逻辑即可>
/**根据id数组批量删除⾳乐@param id@return*/@RequestMapping("/deleteSel")public ResponseBodyMessage<Boolean> deleteSelMusic(@RequestParam("id[]")List<Integer> id) {int sum = 0;for (int i = 0; i < id.size(); i++) {Music music = musicMapper.findMusicById(id.get(i));int ret = musicMapper.deleteMusicById(id.get(i));if(ret == 1) {//数据库删除成功,那么服务器上的数据也需要发⽣改变//删除服务器⽬录下的对应的⽂件int index = music.getUrl().lastIndexOf("=");String filename = music.getUrl().substring(index+1);File file = new File(SAVE_PATH+"\\"+filename+".mp3");if(file.delete()) {sum += ret;}else {System.out.println("删除失败!");return new ResponseBodyMessage<>(-1,"删除服务器上的⾳乐失败",false);}}else {System.out.println("删除失败!");return new ResponseBodyMessage<>(-1,"删除数据上的⾳乐信息失败",false);}}if(sum == id.size()) {System.out.println("删除成功!");return new ResponseBodyMessage<>(0,"批量删除成功",true);}else {System.out.println("删除失败!");return new ResponseBodyMessage<>(0,"批量删除成功",false);}}
批量删除实际也就是将id变成一个id[]的一维数组,在删除时遍历到for循环中,根据给过来的参数遍历删除
五、关键技术解析
-
文件路径处理
-
通过
@Value("${music.local.path}")
读取配置文件中的存储路径 -
从URL参数解析真实文件名(如
/music/get?path=song
→song.mp3
)
-
-
事务性操作
-
数据库删除 → 文件删除原子操作
-
任一环节失败立即返回错误,避免脏数据
-
-
安全校验
-
Session验证确保用户登录状态
-
前置查询防止非法删除
-
-
批量删除优化
-
循环处理每个ID而非单条SQL
-
独立处理每条记录保证部分成功时的可控性
-
总结:删除功能通过三层架构实现:
实体层映射数据结构
Mapper层操作数据库
Controller层协调业务逻辑与文件操作
关键点在于保持数据库记录与物理文件的同步,并通过严格校验保证系统安全性。
代码仓库:删除音乐接口开发 7.22 ·/音乐服务器 - Gitee.com