implemented res.writeBinary() to directly write a java byte array to the response
This commit is contained in:
parent
d45f3240ce
commit
63b63db8b5
1 changed files with 21 additions and 5 deletions
|
@ -51,6 +51,7 @@ public class ResponseTrans implements Externalizable {
|
|||
public void reset () {
|
||||
if (buffer != null)
|
||||
buffer.setLength (0);
|
||||
response = null;
|
||||
redirect = null;
|
||||
skin = null;
|
||||
title = head = body = message = error = "";
|
||||
|
@ -140,18 +141,33 @@ public class ResponseTrans implements Externalizable {
|
|||
throw new RedirectException (url);
|
||||
}
|
||||
|
||||
/**
|
||||
* Allow to directly set the byte array for the response. Calling this more than once will
|
||||
* overwrite the previous output. We take a generic object as parameter to be able to
|
||||
* generate a better error message, but it must be byte[].
|
||||
*/
|
||||
public void writeBinary (byte[] what) {
|
||||
/* if (what == null || !(what instanceof byte[])) {
|
||||
String type = what == null ? "null" : what.getClass ().getName();
|
||||
throw new RuntimeException ("Parameter for res.writeBinary must be byte[], but was "+type);
|
||||
} */
|
||||
response = what;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* This has to be called after writing to this response has finished and before it is shipped back to the
|
||||
* web server. Transforms the string buffer into a char array to minimize size.
|
||||
*/
|
||||
public synchronized void close () {
|
||||
if (response == null) {
|
||||
if (buffer != null) {
|
||||
response = buffer.toString ().getBytes ();
|
||||
buffer = null; // make sure this is done only once, even with more requsts attached
|
||||
} else {
|
||||
response = new byte[0];
|
||||
}
|
||||
}
|
||||
notifyAll ();
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue