视频上传时的分块与合并处理(断点续传)

@TOC

1. 视频分块:

1.1 代码

    @Test
    public void testChunk() throws IOException {

        File source = new File("D:\\r'j'j\\video\\mmexport1644814789468.mp4");
        File chunk = new File("D:\\r'j'j\\video\\chunk\\");

        //每块大小
        long chunkSize = 1024 * 1024 * 5;
        //分块数量(向上取整)
        long chunkNum = (long) Math.ceil(source.length() * 1.0 / chunkSize);
        //设置缓存区
        byte[] bytes = new byte[1024];
        //设置流
        RandomAccessFile raf_read = new RandomAccessFile(source,"r");
        //分块
        for (long i = 0; i < chunkNum; i++) {
            //创建分块文件
            File chunkFile = new File("D:\\r'j'j\\video\\chunk\\"+i);
            if (chunkFile.exists()) chunkFile.delete();

            RandomAccessFile raf_write = new RandomAccessFile(chunkFile,"rw");
            int len = -1;
            while ((len= raf_read.read(bytes))!=-1){
                raf_write.write(bytes,0,len);
                if (chunkFile.length()>=chunkSize) break;
            }
            raf_write.close();
            System.out.println("完成分块"+i);
        }
        raf_read.close();
    }

1.2 结果

在这里插入图片描述

2. 视频合并:

2.1 代码

@Test
    public void testMerge() throws IOException {
        File source = new File("D:\\r'j'j\\video\\mmexport1644814789468.mp4");
        File chunk = new File("D:\\r'j'j\\video\\chunk\\");
        File mergeFile = new File("D:\\r'j'j\\video\\merge.mp4");
        mergeFile.createNewFile();

        //取出所有分块文件
        File[] files = chunk.listFiles();

        List<File> fileList = Arrays.asList(files);
        //排序
        Collections.sort(fileList, new Comparator<File>() {
            @Override
            public int compare(File o1, File o2) {
                return Integer.parseInt(o1.getName())-Integer.parseInt(o2.getName());
            }
        });

        byte[] bytes = new byte[1024];
        RandomAccessFile raf_write = new RandomAccessFile(mergeFile,"rw");
        //合并
        for (File file : fileList) {
            RandomAccessFile raf_read = new RandomAccessFile(file,"r");
            int len = -1;
            while ((len= raf_read.read(bytes))!=-1){
                raf_write.write(bytes,0,len);
            }
            raf_read.close();
        }
        raf_write.close();
        //MD5检测是否与源文件一致
        try{
            FileInputStream sourceInputStream = new FileInputStream(source);
            FileInputStream mergeInputStream = new FileInputStream(mergeFile);
            String a= DigestUtils.md5Hex(sourceInputStream);
            String b= DigestUtils.md5Hex(mergeInputStream);
            if (a.equals(b)) System.out.println("合并成功!");
        }catch (Exception e){

        }
    }

2.2 结果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值