Java 例外情况说明;“重置为无效标记”;对于大文件,在标记输入流并重置它时出现。?

Java 例外情况说明;“重置为无效标记”;对于大文件,在标记输入流并重置它时出现。?,java,file-io,inputstream,Java,File Io,Inputstream,我使用InputStream对象来计算某个文件的Md5。 我在小溪上做记号 后来我重置了流。但是,对于大文件,出现以下异常 inStreamLatestFile.mark(0); checkSumCalculated = MD5CheckSumCalculator.calculateMD5CheckSum(inStreamLatestFile); inStreamLatestFile.reset(); 例外 .Md5ValidationAggrStrat ||**Error in calcul

我使用InputStream对象来计算某个文件的Md5。 我在小溪上做记号 后来我重置了流。但是,对于大文件,出现以下异常

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);