Мне нужно сгенерировать ZIP-файл с данными на лету из сервлета. Я передаю ServletOutputSream конструктору ZipOutputStream, и он отправляет ZIP клиенту правильно. Когда результат ZIP большой, сервлет отвечает много. Я полагаю, что сначала создает ZIP, а затем отправить его.
Я создаю вспомогательный класс, который упаковывает ZipOutputStream.
Мне нужно, чтобы при вызове метода сброса уже созданный фрагмент ZIP был отправлен немедленно. Как я могу это сделать?
public class ZIPResponse {
private ZipOutputStream out;
private HttpServletResponse response;
private boolean isFirstEntry;
private ConnectionManager con;
public ZIPResponse(ConnectionManager con, OutputStream out) throws IOException {
this.out = new ZipOutputStream(out);
isFirstEntry = true;
this.con = con;
}
public ZIPResponse(ConnectionManager con, HttpServletResponse response) throws IOException {
this(con, response.getOutputStream());
this.response = response;
response.setCharacterEncoding("ISO-8859-1");
sendNewEntry("con");
flush();
}
public void sendNewEntry(String dataName) throws IOException {
if (isFirstEntry) {
isFirstEntry = false;
} else {
out.closeEntry();
}
out.putNextEntry(new ZipEntry(dataName));
}
public void sendData(String dataName, String data) throws IOException {
sendNewEntry(dataName);
sendData(data);
}
public void sendData(byte[] bytes) throws IOException {
out.write(bytes);
flush();
}
public void sendData(String data) throws IOException {
sendData(data.getBytes());
}
public void sendAndCloseData(String dataName, String data) throws IOException {
sendNewEntry(dataName);
sendData(data);
close();
}
private void sendDataFile(String dataName, DataTransformer dt)
throws IOException, SQLException {
sendNewEntry(dataName);
dt.sendResultSet(this);
}
public void sendDataFile(String dataName, ResultSet data, String[] columnsRestriction) throws IOException,
SQLException {
RestrictedDataTransformer dt = new RestrictedDataTransformer(data, columnsRestriction);
sendDataFile(dataName, dt);
}
public void sendDataFile(String dataName, ResultSet data) throws IOException,
SQLException {
DataTransformer dt = new DataTransformer(data);
sendDataFile(dataName, dt);
}
public void sendDataFile(String dataName, PreparedStatement p) throws
SQLException, IOException {
ResultSet data = p.executeQuery();
sendDataFile(dataName, data);
}
public void sendDataFile(String dataName, String SQL, String[] columnsRestricted)
throws DBException, SQLException, IOException {
ResultSetStatement st = new ResultSetStatement(con, SQL);
ResultSet valores = st.executeQuery();
try {
sendDataFile(dataName, valores, columnsRestricted);
} finally {
valores.close();
}
}
public void sendDataFile(String dataName, String SQL) throws DBException, SQLException, IOException {
ResultSetStatement st = new ResultSetStatement(con, SQL);
ResultSet valores = st.executeQuery();
try {
sendDataFile(dataName, valores);
} finally {
valores.close();
}
}
public void sendAndCloseDataFile(String dataName, ResultSet data) throws
SQLException, IOException {
sendDataFile(dataName, data);
close();
}
public void sendAndCloseDataFile(String dataName, String SQL) throws DBException, SQLException, IOException {
sendDataFile(dataName, SQL);
close();
}
public void close() throws IOException {
sendNewEntry("OK");
out.closeEntry();
out.close();
flush();
}
public void flush() throws IOException {
out.flush();
response.flushBuffer();
}
}