我正在研究一个Java Web应用程序,其中文件将存储在数据库中。最初,我们只需调用getBytes
结果集即可检索数据库中已有的文件:
byte[] bytes = resultSet.getBytes(1);
...
然后DataHandler
使用显而易见的构造函数将此字节数组转换为:
dataHandler=new DataHandler(bytes,"application/octet-stream");
直到我们开始尝试存储和检索更大的文件之前,这一直很好。将整个文件内容转储到字节数组中,然后再从中构建DataHandler
出来,仅需要太多内存。
我的直接想法是使用来检索数据库中的数据流,getBinaryStream
并以某种内存有效的方式将其转换InputStream
为数据流DataHandler
。不幸的是,似乎没有直接的方法可以将转换InputStream
为DataHandler
。我一直在玩的另一个想法是从中读取数据块InputStream
并将其写入的OutputStream
中DataHandler
。但是…我找不到一种方法来创建一个“空”
DataHandler
,OutputStream
当我打电话时它会返回非空值getOutputStream
。
有人做过吗?我会很感激您能给我或引导正确方向的任何帮助。
问题内容: 我有将ZipInputSream转换为byte []的代码,但我不知道如何将其转换为inputstream。 问题答案: 这是我解决此问题的方法。现在,我可以将单个文件从ZipInputStream作为InputStream传输到内存。
问题内容: 我正处于开发阶段,在那里我有两个模块,从一个模块我得到的输出为a OutputStream,第二个模块仅接受InputStream。您是否知道如何转换OutputStream为InputStream可以连接这两部分的方式(反之亦然,我是说真的) 谢谢 问题答案: 是您向其中写入数据的地方。如果某个模块公开了,则期望在另一端读取一些内容。 另一方面,暴露出的信息表示您需要侦听此流,并且会
问题内容: 我正在使用servlet上传图像。为了执行调整大小的操作,我将InputStream转换为BufferedImage。现在我想将其保存在mongoDB中。因为据我所知,我是mongoDB的新手,所以GridFS采用InputStream。 那么,有什么方法可以将BufferedImage转换为InputStream吗? 问题答案: 您需要使用该类将BufferedImage保存为,然后
问题内容: 如何将java对象转换为InputStream? 问题答案: 您可以使用ObjectOutputStream 您将对象(以下代码中的obj)写入ObjectOutputStream,要转换为输入流的对象必须实现Serializable。
我在/raw文件夹中有一个名为“max_easy.txt”的txt文件,在这个文件中写了一个数字,在本例中为“0”...我想要一个以0作为Int值的var,我怎么做? 我猜这行给了我一个字符串值,我怎么转换它?
问题内容: 有没有一种简单的方法可以避免处理文本编码问题? 问题答案: 您确实无法避免处理文本编码问题,但是Apache Commons中已有一些解决方案: 至: 至: 您只需要选择所需的编码即可。