技术框架版本:hessian 3.16+spring 2.5
由于hessian不支持文件传输,所以我们将文件内容保存到byte数组中,然后返回给客户端,客户端再将字节写到文件中,文件读取采用随机文件读取方式。
示例如下:
hessian 4.0提供了文件传输功能,具体可以看:
http://hessian.caucho.com/doc/hessian-overview.xtp
但是由于担心文件太大可能导致内存溢出,所以没有采用这种方式。根据文档意思,这种方式不能使用代理,需要手工完成hessian2Input等的操作就可以避免内存溢出问提,目前我还不会。
这个也可参考:
http://weishuwei.iteye.com/blog/92449
由于hessian不支持文件传输,所以我们将文件内容保存到byte数组中,然后返回给客户端,客户端再将字节写到文件中,文件读取采用随机文件读取方式。
示例如下:
public interface ISynFile
{
/**
*@param filename 需要下载的文件名
*@param offset 从offset位置开始读取文件
*@param length 读取字节数
*/
byte[] downloadFile( String filename, long offset, int length);
}
public SynFile implements ISynFile
{
public byte[] downloadFile( String filename, long offset, int length)
{
RandomAccessFile rf = null;
rf.seek(offset);
byte buffer[] = new byte[length];
int readLen = rf.read(buffer);
rf.close();
return buffer;
}
}
hessian 4.0提供了文件传输功能,具体可以看:
http://hessian.caucho.com/doc/hessian-overview.xtp
但是由于担心文件太大可能导致内存溢出,所以没有采用这种方式。根据文档意思,这种方式不能使用代理,需要手工完成hessian2Input等的操作就可以避免内存溢出问提,目前我还不会。
这个也可参考:
http://weishuwei.iteye.com/blog/92449