相关文章推荐
爱笑的楼梯  ·  Kotlin Coroutines ...·  1 年前    · 
老实的领结  ·  CS224W-图神经网络 ...·  1 年前    · 
非常酷的斑马  ·  如何使用 Html 和 ...·  1 年前    · 
@ApiOperation(value = "mp3", notes = "播放mp3")
    @GetMapping("/mp3")
    public void mp3(@ApiParam(value = "mp3路径") @RequestParam String path, HttpServletResponse response, HttpServletRequest request) {
        String database =this.fileDir + path;
        // 文件目录(偷懒没有改变量,名称,此处和FTP没关系,就是文件的绝对路径)
        // 也就是 File music = new File("C:\Users\Administrator\AppData\Local\Temp\a.mp3");
        File music = new File(database);
        String range = request.getHeader("Range");
        //开始下载位置
        long startByte = 0;
        //结束下载位置
        long endByte = music.length() - 1;
        //有range的话
        if (range != null && range.contains("bytes=") && range.contains("-")) {
            range = range.substring(range.lastIndexOf("=") + 1).trim();
            String ranges[] = range.split("-");
            try {
                //判断range的类型
                if (ranges.length == 1) {
                    //类型一:bytes=-2343
                    if (range.startsWith("-")) {
                        endByte = Long.parseLong(ranges[0]);
                    //类型二:bytes=2343-
                    else if (range.endsWith("-")) {
                        startByte = Long.parseLong(ranges[0]);
                //类型三:bytes=22-2343
                else if (ranges.length == 2) {
                    startByte = Long.parseLong(ranges[0]);
                    endByte = Long.parseLong(ranges[1]);
            } catch (NumberFormatException e) {
                startByte = 0;
                endByte = music.length() - 1;
        //要下载的长度
        long contentLength = endByte - startByte + 1;
        //文件名
        String fileName = music.getName();
        //文件类型
        String contentType = request.getServletContext().getMimeType(fileName);
        //各种响应头设置
        //参考资料:https://www.ibm.com/developerworks/cn/java/joy-down/index.html
        //坑爹地方一:看代码
        response.setHeader("Accept-Ranges", "bytes");
        //坑爹地方二:http状态码要为206
        response.setStatus(206);
        response.setContentType(contentType);
        response.setHeader("Content-Type", contentType);
        //这里文件名换你想要的,inline表示浏览器直接实用(我方便测试用的)
        //参考资料:http://hw1287789687.iteye.com/blog/2188500
        // response.setHeader("Content-Disposition", "inline;filename=test.mp3");
        response.setHeader("Content-Length", String.valueOf(contentLength));
        //坑爹地方三:Content-Range,格式为
        // [要下载的开始位置]-[结束位置]/[文件总大小]
        response.setHeader("Content-Range", "bytes " + startByte + "-" + endByte + "/" + music.length());
        BufferedOutputStream outputStream = null;
        RandomAccessFile randomAccessFile = null;
        //已传送数据大小
        long transmitted = 0;
        try {
            randomAccessFile = new RandomAccessFile(music, "r");
            outputStream = new BufferedOutputStream(response.getOutputStream());
            byte[] buff = new byte[4096];
            int len = 0;
            randomAccessFile.seek(startByte);
            //坑爹地方四:判断是否到了最后不足4096(buff的length)个byte这个逻辑((transmitted + len) <= contentLength)要放前面!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
            //不然会会先读取randomAccessFile,造成后面读取位置出错,找了一天才发现问题所在
            while ((transmitted + len) <= contentLength && (len = randomAccessFile.read(buff)) != -1) {
                outputStream.write(buff, 0, len);
                transmitted += len;
                //停一下,方便测试,用的时候删了就行了
                Thread.sleep(10);
            //处理不足buff.length部分
            if (transmitted < contentLength) {
                len = randomAccessFile.read(buff, 0, (int) (contentLength - transmitted));
                outputStream.write(buff, 0, len);
                transmitted += len;
            outputStream.flush();
            response.flushBuffer();
            randomAccessFile.close();
            System.out.println("下载完毕:" + startByte + "-" + endByte + ":" + transmitted);
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            try {
                if (randomAccessFile != null) {
                    randomAccessFile.close();
            } catch (IOException e) {
                e.printStackTrace();
 

https://blog.csdn.net/weixin_38497019/article/details/90475980

该项目是基于SpringBoot和Vue的前后端分离系统,前端分为前台用户和后台管理员界面,可以说系统功能非常全面,界面也做的十分优秀,具体的演示效果可以参照我的博客。和在线考试系统、人事管理系统或者二手车交易平台这些课题相比,经管这些课题做出来的系统也很不错,但是界面千篇一律,没有实际的功效。而本课题可以展示实际应用,而且无论功能和界面都非常新颖。所以该项目绝对是让老师眼前一亮的优秀毕业设计! 博客介绍地址:https://blog.csdn.net/qq_42257666/article/details/117195304 之前一直想做一个MP3播放器,普遍的方案都比较复杂,用音频解码芯片还有其他芯片的方案,开发起来不太容易。偶然的一个机会看到这种简单的串口播放器,就跟大家分享一下这个过程,大家也可以自己制作下,弄个好的造型,外加功放和喇叭,那就更完美,放在枕边听着,舒服。设计使用的是MY1690-12P语音模块,支持UART 异步串口控制:支持播放、暂停、上下曲、音量加减、选曲播放、插播等。模块最大支... controller类如下 @GetMapping(value = "/downfile") public void download(HttpServletResponse response) throws IOException { String fileName = "template.xlsx"; // 设置信息给客户端不解析 String type = new M 文章目录前言HttpServletResponseHttpMessageConverter配置实现ResponseEntityResource实现结论 项目开发中,会经常遇到需要下载的功能,即后台返回图片、音视频这类的文件流,记录下多种实现方式。 HttpServletResponse HttpMessageConverter ResponseEntity Resource HttpServletResponse 图像下载的最基本方法是直接针对响应对象实现: @RequestMapping(val 本项目是一个前后端分离的音乐播放系统项目,前端使用的Vue,后端使用的SpringBoot前端分为前台用户界面和后台管理员界面。 用户界面的功能除了最基本的播放暂停、上一首下一首、下载歌曲,还有搜索、收藏、同步歌词、评分和评论功能。 2.网站应有的数据有:歌手数据集,歌曲数据,歌单数据,用户对歌曲的操作数据,用户对歌单的操 作数据。Mapper 层 / DAO 层(dao、mapper 目录下) 29。3. 管理员能对网站的一切数据进行修改 25。3.管理员能对网站的一切数据进行修改。数据字典设计(表设计) 30。D BMS及辅助软件 1。系 统使用手册 46。 A2DP音频流在安卓系统中的实现通过前一篇文章《蓝牙音乐之A2DP音频流》的分享,大家都清楚了A2DP音频流的开启、暂停、数据传输等一系列协议规定,今天就带大家一探安卓系统中这部分是如何实现的。这篇文章主要分享下A2DP协议中SNK端的音频流的工作,那这就离不开 AudioTrack。AudioTrack的工作原理这里就不做说明,对安卓系统中的音频感兴趣的小伙伴相信你们可以找到学习渠道的。SNK端... * 通过HttpServletResponse将文件返回前端 * @param response HttpServletResponse在Controller层直接接收即可 * @param is 需要返回文件流 * @param fileName 文件名 * @return private static ResponseEntity<InputStreamResource> encapsulateResponseEntities(HttpS SpringBoot+ElementUI实现通用文件下载请求(全流程图文详细教程): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/107983093 在使用了通用下载接口下载一些文件后,有些业务比如上传头像,富文本上传照片,此类业务都需要将 某些文件上传到服务器上,并返回文件的全路径,给具体的业务前端返回进行回显数据或下载文件用。 同时为了后期文件数量过多,最好是按照时间在服务器上新建不用的文件夹,并且给上传的文件的 import org.apache.commons.io.IOUtils;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.core.io.ResourceLoader;import org.springframework.beans.factory.annotation...