当前位置: 首页 > news >正文

Java音频和录音合成 实战demo

@Api(tags = {"APP音频合成"})
@RestController
@RequestMapping("/app")
public class AudioFileController {


    @Autowired
    private IAudioFileService audioFileService;




    /**
     * 合成音频
     *
     * @param audioFile     录音文件
     * @param audioUrl      背景音乐url链接
     * @return
     */
    @ApiOperation(value = "合成音频", notes = "【请求参数】<br> MultipartFile audioFile  录音文件" +
            "                                           <br> String audioUrl  背景音乐url链接")
    @PostMapping("/mergeAudioFile")
    public AjaxResult mergeAudioFile(@RequestPart("audioFile") MultipartFile audioFile,
                                     @RequestParam String audioUrl) {
        return audioFileService.mergeAudioFile(audioFile, audioUrl);
    }
}

    /**
     * 合成音频文件
     * 该方法将合并上传的音频文件和URL指定的音频文件,并上传到阿里云OSS
     *
     * @param audioFile 录音文件
     * @param audioUrl  背景音乐url链接
     * @return 合成后音频文件的下载链接
     */
    public AjaxResult mergeAudioFile(MultipartFile audioFile, String audioUrl) {

        // 记录方法开始时间
        Instant start = Instant.now();

        File mergedAudioFile = null;
        String fileUrl = "";
        try {
            // 1. 下载通过URL提供的音频文件
            byte[] audioFileFromUrl = downloadAudioFromUrl(audioUrl);

            // 2. 获取上传的音频文件
            byte[] uploadedAudioFile = audioFile.getBytes();

            // 3. 合并音频文件
            mergedAudioFile = mergeAudioFiles(uploadedAudioFile, audioFileFromUrl);

            // 4. 上传合成后的音频文件到阿里云OSS
//            fileUrl = ossUtils.uploadFileToOSS(mergedAudioFile, null, true);
            fileUrl = ossUtils.uploadFile(mergedAudioFile, null, true, null); //分片上传

            AjaxResult ajaxResult = new AjaxResult();
            Map<String, String> map = Maps.newHashMap();
            map.put("mergeAudioUrl",fileUrl);
            ajaxResult.put("code", 200);
            ajaxResult.put("msg", "合成音频成功");
            ajaxResult.put("data", map);
            // 5. 返回OSS文件的下载链接
            return ajaxResult;
        } catch (Exception e) {
            return AjaxResult.error("合成音频失败:" + e.getMessage());
        }finally {
            // 删除临时音频文件
            if (mergedAudioFile != null && mergedAudioFile.exists()) {
                mergedAudioFile.delete();
            }

            // 记录方法结束时间
            Instant end = Instant.now();
            // 打印耗时
            long duration = java.time.Duration.between(start, end).toMillis();
            log.info("合成音频文件的耗时: {} 毫秒, mergeAudioUrl: {}", duration, fileUrl);
        }
    }





    /**
     * 从URL下载音频文件
     *
     * @param audioUrl 音频文件的URL
     * @return 下载的音频文件的字节数组
     * @throws IOException 如果下载失败,抛出异常
     */
    private byte[] downloadAudioFromUrl(String audioUrl) throws IOException {
        URL url = new URL(audioUrl);
        try (InputStream in = url.openStream()) {
            return IOUtils.toByteArray(in);
        }
    }



    /**
     * 合并两个音频文件并返回合成后的音频文件
     *
     * @param audio1        录音文件
     * @param audio2        背景音乐url链接
     * @return
     * @throws IOException
     */
    public File mergeAudioFiles(byte[] audio1, byte[] audio2) throws IOException {
        // 创建临时文件保存音频文件
        File audioFile1 = byteArrayToFile(audio1, "audio1_" + RandomNumberUtils.getRandomString(17, true) + ".mp3");
        File audioFile2 = byteArrayToFile(audio2, "audio2_" + RandomNumberUtils.getRandomString(17, true) + ".mp3");

        // 临时文件用于存储合并后的音频
        File mergedAudioFile = new File("mergedAudio_" + RandomNumberUtils.getRandomString(17, true) + ".mp3");

        // TODO  访问该地址复制源码: https://stjl.xyz

        // 将合并后的音频文件读取为字节数组并返回
//        Files.readAllBytes(mergedAudioFile.toPath()); // 返回byte[]
        return mergedAudioFile;
    }

https://stjl.xyz/ 

相关文章:

  • Linux 部署 rocketmq centos7
  • 读一本书,骑行万里路:与维乐 Angel Rise+骑行看世界
  • ai画图flux depth景深控制空间位置生图
  • 软件工程之软件测试(单元测试、集成测试、系统测试)
  • 06.AI搭建preparationの(transformers02)bertmodel实现bert-base-chinese的编码
  • 论文阅读笔记——PointVLA: Injecting the 3D World into Vision-Language-Action Models
  • DevEco Studio编辑器的使用-代码code Linter检查
  • 【博客】使用GithubAction自动同步obisidian和hexo仓库
  • QTableView开发入门
  • @DeclareParents 注解实现接口功能增强:Spring中通过接口引入实现功能增强的完整示例
  • 保存预测图像时出现的文件名错误
  • Python----机器学习(KNN:决策边界,决策边界计算,交叉验证步骤)
  • ansible介绍以及安装
  • C++练习
  • C# dataGridView 自动生成几行几列及手动输入整型字符
  • nginx https配置
  • 【算法】并查集基础讲解
  • 每日c/c++题 备战蓝桥杯(全排列问题)
  • DEEPSEEK创业项目推荐:
  • pytorch中不同的mask方法:masked_fill, masked_select, masked_scatter
  • 郑州做网站公司有多少钱/宁波网站制作优化服务
  • 网站设计制作公司推荐/网站查询工具seo
  • 做菠菜网站好赚吗/店铺推广方案怎么写
  • 做企业网站需要提供什么/广告宣传方式有哪些
  • 辽宁朝阳哪家做网站好/国际军事新闻最新消息视频
  • 做h5那个网站好/免费一键生成个人网站