Spring WebFlux单文件与多文件上传

本文主要讲述webflux文件上传
在工作中我们经常遇到需要上传文件至服务器,SpringMVC文件上传网上已有很多案例,但照搬到Webflux则行不通。原因在于在webflux中没有MultipartFile接口的实例,webflux是用FilePart这个接口传递文件的。
我的应用场景是将图片上传至阿里云的OSS,OSSSDK提供了一个将InputStream上传的接口。而要拿到InputStream我需要拿到File因此我借鉴网上的方案写了一个单文件上传的接口,同时发现网上并没有多文件上传的实例,于是有多加改进支持多文件上传。

1.单文件上传

public Mono<String> single(@RequestPart ("file") Mono<FilePart> file) throws IOException {
        return file.map(filePart->{
            Path tempFile = null;
            try {
                tempFile = Files.createTempFile("test", filePart.filename());
            } catch (IOException e) {
                e.printStackTrace();
            }
        AsynchronousFileChannel channel = null;
        try {
            channel = AsynchronousFileChannel.open(tempFile, StandardOpenOption.WRITE);
        } catch (IOException e) {
            e.printStackTrace();
        }
        DataBufferUtils.write(filePart.content(), channel, 0).doOnComplete(() -> {
            System.out.println("finish");
        }).subscribe();
            return tempFile;
        }).map(a->{
            return a.toFile();
            //此时已转换为File类,具体的业务逻辑我就忽略了
        }).flatMap(fileSinge->file.map(FilePart::filename));
    }

2.多文件上传

public Mono<List<String>> more(@RequestPart ("file") Flux<FilePart> file) throws IOException {
        return file.map(filePart->{
            Path tempFile = null;
            try {
                tempFile = Files.createTempFile("test", filePart.filename());
            } catch (IOException e) {
                e.printStackTrace();
            }
            filePart.transferTo(tempFile.toFile());
            return tempFile;
        }).map(a->{
            return a.toFile();
            //此时已转换为File类,具体的业务逻辑我就忽略了
        }).flatMap(fileSinge->file.map(FilePart::filename)).collectList();
    }
  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值