ade*_*asi 2 java spring-mvc mongodb
我有一个 MongoDB,它存储一个 csv 文件和两个微服务(Spring Boot 应用程序)。一个微服务处理文件上传并支持将这些文件作为流获取。另一个微服务处理文件。这些微服务是分开的,因为我可能想稍后以另一种方式存储文件而不是在 MongoDB 中,我不想因此影响其他服务。
我的问题是,当文件服务将文件作为 InputStreamResource 返回时,如下所示:
@RequestMapping(value = "/upload/{importId}", method = RequestMethod.GET)
@ResponseBody
public ResponseEntity<InputStreamResource> getUploadedFile(@PathVariable("importId") String importId)
throws ImportFileNotFoundException {
GridFSDBFile file = FileImportClient.getInstance().getFile(importId);
return ResponseEntity
.ok()
.contentLength(file.getLength())
.body(new InputStreamResource(file.getInputStream()));
}
Run Code Online (Sandbox Code Playgroud)
我想从它已经关闭的流中读取。
ResponseEntity<InputStreamResource> response = restTemplate
.getForEntity("http://upload-service/upload/" + importId, InputStreamResource.class);
BufferedReader fileReader = new BufferedReader(new InputStreamReader(response.getBody().getInputStream()));
for (CSVRecord record : CSVFormat.DEFAULT.parse(fileReader)) {/*toStuff()*/}
Run Code Online (Sandbox Code Playgroud)
我得到了java.io.IOException: Stream closed由 parse 方法引起的。
如果我只是curl localhost:<port>/upload/<importId>得到整个 csv 文件。有谁知道,为什么 InputStream 被关闭以及如何解决这个问题?
堆栈跟踪:
java.io.IOException: Stream closed
at java.io.BufferedInputStream.getBufIfOpen(BufferedInputStream.java:170)
at java.io.BufferedInputStream.read(BufferedInputStream.java:336)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
at java.io.InputStreamReader.read(InputStreamReader.java:184)
at java.io.BufferedReader.read1(BufferedReader.java:210)
at java.io.BufferedReader.read(BufferedReader.java:286)
at java.io.BufferedReader.fill(BufferedReader.java:161)
at java.io.BufferedReader.read(BufferedReader.java:182)
at org.apache.commons.csv.ExtendedBufferedReader.read(ExtendedBufferedReader.java:60)
at org.apache.commons.csv.Lexer.nextToken(Lexer.java:89)
at org.apache.commons.csv.CSVParser.nextRecord(CSVParser.java:498)
at org.apache.commons.csv.CSVParser$1.getNextRecord(CSVParser.java:439)
at org.apache.commons.csv.CSVParser$1.hasNext(CSVParser.java:452)
at <mypackage>.<myclass>.process(<myclass>.java:71)
Run Code Online (Sandbox Code Playgroud)
我通过这个链接找到了解决方案:https : //jira.spring.io/browse/SPR-7357
[这回答了我的问题] 请注意,您不能简单地从提取器返回 InputStream,因为到 execute 方法返回时,底层连接和流已经关闭
[这解决了问题] 您已经可以通过使用 RestTemplate 上的 execute() 方法结合 ResponseExtractor 实现来读取 InputStream
我尝试使用 ResponseExtractor,现在它可以工作了。它看起来像这样:
return restTemplate.execute(new URI("http://<myservice>/upload/" + importId), HttpMethod.GET, null,
new ResponseExtractor<MyObject>() {
@Override
public MyObject extractData(ClientHttpResponse response) throws IOException {
CSVParser parse = CSVFormat.DEFAULT.parse(new BufferedReader(new InputStreamReader(response.getBody())));
for (CSVRecord record : parse) {/*dostuff*/}
return new MyObject();
}
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5425 次 |
| 最近记录: |