Java 例外情况说明;“重置为无效标记”;对于大文件,在标记输入流并重置它时出现。?
我使用InputStream对象来计算某个文件的Md5。 我在小溪上做记号 后来我重置了流。但是,对于大文件,出现以下异常Java 例外情况说明;“重置为无效标记”;对于大文件,在标记输入流并重置它时出现。?,java,file-io,inputstream,Java,File Io,Inputstream,我使用InputStream对象来计算某个文件的Md5。 我在小溪上做记号 后来我重置了流。但是,对于大文件,出现以下异常 inStreamLatestFile.mark(0); checkSumCalculated = MD5CheckSumCalculator.calculateMD5CheckSum(inStreamLatestFile); inStreamLatestFile.reset(); 例外 .Md5ValidationAggrStrat ||**Error in calcul
inStreamLatestFile.mark(0);
checkSumCalculated = MD5CheckSumCalculator.calculateMD5CheckSum(inStreamLatestFile);
inStreamLatestFile.reset();
例外
.Md5ValidationAggrStrat ||**Error in calculating checksum:: java.io.IOException: Resetting to invalid mark**
||java.io.IOException: Resetting to invalid mark
||at java.io.BufferedInputStream.reset(BufferedInputStream.java:437)
||at com.amadeus.apt.ib.modules.func.map.camel.strategy.Md5ValidationAggrStrategy.aggregate(Md5ValidationAggrStrategy.java:81)
||at org.apache.camel.processor.aggregate.AggregateProcessor.onAggregation(AggregateProcessor.java:365)
||at org.apache.camel.processor.aggregate.AggregateProcessor.doAggregation(AggregateProcessor.java:245)
||at org.apache.camel.processor.aggregate.AggregateProcessor.process(AggregateProcessor.java:201)
||at org.apache.camel.util.AsyncProcessorConverterHelper$ProcessorToAsyncProcessorBridge.process(AsyncProcessorConverterHelper.java:61)
||at org.apache.camel.util.AsyncProcessorHelper.process(AsyncProcessorHelper.java:73)
我尝试过关闭流并以这种方式重新打开它。。下面是一些例外情况:
try {
inStreamLatestFile= ExchangeHelper.getMandatoryInBody(
oldExchange, InputStream.class);
//inStreamLatestFile.mark(0);
checkSumCalculated = MD5CheckSumCalculator.calculateMD5CheckSum(inStreamLatestFile);
//closing the inputStream of the latest file
if(inStreamLatestFile != null){
try {
inStreamLatestFile.close();
} catch (IOException e) {
logger.error("Error occurred in closing the stream :: "+ e.getMessage());
}
}
tempInputStream= ExchangeHelper.getMandatoryInBody(
oldExchange, InputStream.class);
oldExchange.getIn().setBody(tempInputStream);
但是,当我尝试恢复新检索的InputStream时,出现以下异常
caught: java.io.IOException: Stream closed: java.io.IOException: Stream closed
at java.io.BufferedInputStream.getBufIfOpen(BufferedInputStream.java:162)
我假设您使用的是
BufferedInputStream
,因为reset()
方法的源代码是
public synchronized void reset() throws IOException {
getBufIfOpen(); // Cause exception if closed
if (markpos < 0)
throw new IOException("Resetting to invalid mark"); // exception you are getting
pos = markpos;
}
必须对markPos
执行某些操作
如果您无法控制它,只需重新打开流即可。如果无法重新打开流,则每次都检索相同的实例,考虑使用<代码> BytErayOuttoStuts
您可以通过tearrayoutputstream将原始的
InputStream
读入中。将该流中的字节复制到新的ByteArrayInputStream
。将其传递给MD5计算器。然后用相同的字节再次创建一个新的ByteArrayInputStream
,并将其传递给您需要的任何其他文件。是否可能calculateMD5CheckSum
也标记流?非常感谢您解决此问题。。不,它是第三方Api,我无法控制它。这个方法只会更改inputStream,因此我需要标记并重置流,因为我以后需要它……可能是getMandatoryInBody
每次都返回相同的流实例。我不知道那个API。是的,这可能是一个问题。{我正在使用apache camel framework}所以基本上可以归结为这个问题,如何创建一个重复的inputStream,使对象是不同的实例??您可以通过tearrayoutputstream将原始的InputStream
读入中。将该流中的字节
复制到新的ByteArrayInputStream中
。将其传递给MD5计算器。使用相同的字节再次创建一个新的ByteArrayInputStream
,并将其传递给您需要的任何其他文件。@Kumar最初是如何初始化流内文件的?只需关闭并重新初始化它。您正在重用同一个关闭的流,而不是重新初始化的流。
MD5CheckSumCalculator.calculateMD5CheckSum(inStreamLatestFile);