Zipping multiple BLOBs
Hello,
First of all, I have virtually no experience with Java but I've been
tasked with putting this thing together and I've finally hit a dead
end. Basically, what I am creating is a PL/SQL (Oracle 10g) web form
so that clients may download specific files stored as BLOBs from the
database. This is fine and dandy if they want to download one file at
a time. What I need to do is come up with a way to pull multiple BLOB
files, zip them up in one big BLOB, and serve it as a download. Since
this cannot be done in PL/SQL alone, I turned to Java.
So far I have not been able to find one successful example of how to
do this. What I have so far produces a zip file with only the first of
the selected BLOBs inside of it. I am basically just looping through
the list of selected BLOBs while passing each selected BLOB to the
Java procedure as well as the zip BLOB but it doesn't seem to be
appending anything to the zipped BLOB after the first iteration. Here
is the code:
public static void zipBlob(oracle.sql.BLOB srcBlob, oracle.sql.BLOB
dstBlob[],java.lang.String name)
{
try
{
Connection conn =
DriverManager.getConnection("jdbc:default:connection:");
OutputStream outBuffer = dstBlob[0].setBinaryStream(0);
InputStream inBuffer = srcBlob.getBinaryStream();
ZipOutputStream zip = new ZipOutputStream(outBuffer);
zip.setMethod(ZipOutputStream.DEFLATED);
byte[] tmpBuffer = new byte[1024];
ZipEntry entry = new ZipEntry(name);
zip.putNextEntry(entry);
int n;
while ((n = inBuffer.read(tmpBuffer)) >= 0)
{
zip.write(tmpBuffer, 0, n);
}
zip.close();
}
catch (SQLException e)
{
System.err.println(e);
}
catch (IOException e)
{
System.err.println(e);
}
}
I appreciate any examples or pointers as to why this is not working.
Thanks