Mantis Bugtracker

Viewing Issue Simple Details Jump to Notes ] View Advanced ] Issue History ] Print ]
ID Category Severity Reproducibility Date Submitted Last Update
0003655 [Hessian] minor always 08-28-09 08:51 07-18-11 12:12
Reporter ferg View Status public  
Assigned To
Priority normal Resolution open  
Status new   Product Version 4.0.1
Summary 0003655: Hessian InputStream result is closed
Description (rep by Mattias Jiderhamn)
After upgrading from Resin/Hessian 3.1 to 4.0.1 we have a problem
returning InputStream from Hessian calls.
I get this exception while trying to read the stream on the client: stream is closed

I created a small testcase which just sends the output of a
Hessian2Output to a Hessian2Input and in that case, InputStream works fine.

The proxy is created using Springs HessianProxyFactoryBean.

Any tips on how to debug this???

Additional Information
Attached Files  Hessian_3000655.patch [^] (571 bytes) 08-28-09 09:46

- Relationships

- Notes
Peter Dettman
08-28-09 09:49

I was able to reproduce Mattias' issue, and tracked the problem down to HessianProxy (see attached patch). The call to http.disconnect in the finally block of the invoke method was causing the reply to be truncated. I have copied the handling for Hessian 1 'InputStream' replies and it appears to fix the problem.
04-26-10 03:46

Hi Hessian team

Any chance that this gets fixed in the next official minor/major release? I just hit the same bug using resin-hessian 4.0.3 on the server side, and hessian-4.0.3 on the client side.
07-29-10 14:17

This bug exists in 4.0.7, and the attached patch works very well for this version.

Any change to get it in 4.0.8?
12-09-10 12:39

Is there a reason this bug has not been resolved? The solution works perfectly. Without the fix transferring/downloading files is broken in Hessian 4.
02-15-11 07:26

Hello, is there a chance to get this patch to next release? And is there a time plan for this release? Thx
07-18-11 12:12
edited on: 07-18-11 12:13

Could someone please include this fix in the next release? I'd update the SVN myself, but I'm not familiar with the repository.

You just need to update src/com/caucho/hessian/client/ and add:

    if (value instanceof InputStream) {
            value = new ResultInputStream(conn, is, in, (InputStream) value);
            is = null;
            conn = null;

After line:

Object value = in.readReply(method.getReturnType());

I've verified it as solving the issue.


- Issue History
Date Modified Username Field Change
08-28-09 08:51 ferg New Issue
08-28-09 09:46 Peter Dettman File Added: Hessian_3000655.patch
08-28-09 09:49 Peter Dettman Note Added: 0004196
08-28-09 09:50 Peter Dettman Issue Monitored: Peter Dettman
08-30-09 11:25 mate Issue Monitored: mate
04-26-10 03:46 stefanthurnherr Note Added: 0004545
04-26-10 03:49 stefanthurnherr Issue Monitored: stefanthurnherr
07-29-10 14:17 fabdouglas Note Added: 0004686
07-29-10 14:17 fabdouglas Issue Monitored: fabdouglas
12-09-10 12:39 selikoff Note Added: 0004869
02-15-11 07:23 Holy Issue Monitored: Holy
02-15-11 07:26 Holy Note Added: 0005058
06-14-11 05:38 jsbret Issue Monitored: jsbret
07-18-11 12:12 selikoff Note Added: 0005379
07-18-11 12:13 selikoff Note Edited: 0005379
07-18-11 12:13 selikoff Issue Monitored: selikoff

Mantis 1.0.0rc3[^]
Copyright © 2000 - 2005 Mantis Group
54 total queries executed.
37 unique queries executed.
Powered by Mantis Bugtracker