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循环中,根据给过来的参数遍历删除

 


五、关键技术解析
  1. 文件路径处理

    • 通过@Value("${music.local.path}")读取配置文件中的存储路径

    • 从URL参数解析真实文件名(如/music/get?path=song → song.mp3

  2. 事务性操作

    • 数据库删除 → 文件删除原子操作

    • 任一环节失败立即返回错误,避免脏数据

  3. 安全校验

    • Session验证确保用户登录状态

    • 前置查询防止非法删除

  4. 批量删除优化

    • 循环处理每个ID而非单条SQL

    • 独立处理每条记录保证部分成功时的可控性


 

总结:删除功能通过三层架构实现:

  1. 实体层映射数据结构

  2. Mapper层操作数据库

  3. Controller层协调业务逻辑与文件操作
    关键点在于保持数据库记录与物理文件的同步,并通过严格校验保证系统安全性。

代码仓库:删除音乐接口开发 7.22 ·/音乐服务器 - Gitee.com 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值