23

I am using the Java Jersey to implement a REST service. One thing my service should provide is a file download option. These files are quite big and are constructed from data from db.

Currently I am fetching all data from the db and saving it to a file and returning a

Response.ok().entity(new FileInputStream(file)).build();

Is there a way how I can start serving the file without fully downloading the data from db, but as the data comes from db append it to the Output stream ?

1

4 Answers 4

9

Solved the problem by using the answer from Input and Output binary streams using JERSEY?

Sign up to request clarification or add additional context in comments.

Comments

9

How about

File fileToSend = getFile();
return Response.ok(fileToSend, "application/zip").build();

The media type can be set to match the file being sent.

This looks pretty straight forward but more importantly, do java experts reading this see a performance problem with the solution?

2 Comments

Did you actually try this? I would expect that this will just return the file-name as string, not the content of the file...
It did not for me, it indeed returned the fileName.
0

So you want to get a stream from your database ?

I'm not sure it's even possible.

But you don't have to write a temp file to send your data. Instead of writing into the file, you could use a ByteArrayInputStream and put your data there with a byte array.

1 Comment

Yes, I want something like new InputStream(new MyDBWrapper()) where MyDBWrapper would perform the data fetching and formating. I am not sure I can use ByteInputStream as the data is quite big - can get more then 1 GB.
0

depends on the type of underlying database connection/driver, if you have access to the JDBC layer (e.g. using Hibernate) it should be possible to stream data using the JDBC Streaming API, then take the Streams from the ResultSet and pass them into Jersey's Response Builder. I have not done this myself though..

check here:

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.