gpt4 book ai didi

file - spring webflux Flux 转换为 InputStream

转载 作者:行者123 更新时间:2023-12-03 21:22:49 52 4
gpt4 key购买 nike

我目前正在研究 Spring WebFlux。
我正在尝试使用 Spring WebFlux 上传大文件 (70mo)。
我的 Controller

@RequestMapping(method = RequestMethod.POST, consumes = MediaType.MULTIPART_FORM_DATA_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
public Flux<String> uploadHandler(@RequestBody Flux<Part> fluxParts, @RequestParam(value = "categoryType") String categoryType, @PathVariable(value = "traceabilityReportUuid") String traceabilityUuid) {
return documentHandler.upload(fluxParts, UUID.fromString(traceabilityUuid), categoryType);
}
我的服务
public Flux<String> upload(Flux<Part> fluxParts, UUID traceabilityUuid, String categoryType) {

return fluxParts
.filter(part -> part instanceof FilePart)
.ofType(FilePart.class)
.flatMap(p -> this.upload(p, traceabilityUuid, categoryType));


}


private Mono<String> upload(FilePart filePart, UUID traceabilityUuid, String categoryType) {

return filePart.content().collect(InputStreamCollector::new, (t, dataBuffer) -> t.collectInputStream(dataBuffer.asInputStream()))
.flatMap(inputStreamCollector -> {
upload(traceabilityUuid, inputStreamCollector.getInputStream(), filePart.filename(), categoryType);

return Mono.just("OK");
});
}
我的收藏家
public class InputStreamCollector {

private InputStream is;

public void collectInputStream(InputStream is) {
if (this.is == null) this.is = is;
this.is = new SequenceInputStream(this.is, is);
}

public InputStream getInputStream() {
return this.is;
}
}
最后,我通过这种方式检索了完整的输入流: inputStreamCollector.getInputStream()并传递给我的对象。
我使用这个对象来发送到存储桶 S3。
但是在发送到 S3 之前,我必须将其转换为文件(使用 apache 工具),我有一个 stackoverflow 异常。
java.lang.StackOverflowError: null
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
at java.base/java.io.SequenceInputStream.read(SequenceInputStream.java:156)
它适用于小文件(7mo ..)
你有什么想法可以解决我的问题吗?

最佳答案

关于file - spring webflux Flux<DataBuffer> 转换为 InputStream,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51676922/

52 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com