提交 277cf78c 编写于 作者: C chegar

6631048: Problem when writing on output stream of HttpURLConnection

Summary: Fix up logic in ChunkedOutputStream.write
Reviewed-by: jccollet
上级 fb95987e
...@@ -177,14 +177,23 @@ public class ChunkedOutputStream extends PrintStream { ...@@ -177,14 +177,23 @@ public class ChunkedOutputStream extends PrintStream {
return; return;
} }
if (len > MAX_BUF_SIZE) { int l = preferredChunkSize - count;
if ((len > MAX_BUF_SIZE) && (len > l)) {
/* current chunk is empty just write the data */
if (count == 0) {
count = len;
flush (b, false, off);
return;
}
/* first finish the current chunk */ /* first finish the current chunk */
int l = preferredChunkSize - count;
if (l > 0) { if (l > 0) {
System.arraycopy(b, off, buf, count, l); System.arraycopy(b, off, buf, count, l);
count = preferredChunkSize; count = preferredChunkSize;
flush(buf, false); flush(buf, false);
} }
count = len - l; count = len - l;
/* Now write the rest of the data */ /* Now write the rest of the data */
flush (b, false, l+off); flush (b, false, l+off);
......
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
/** /**
* @test * @test
* @bug 5026745 * @bug 5026745 6631048
* @run main/othervm/timeout=500 Test * @run main/othervm/timeout=500 Test
* @summary Cannot flush output stream when writing to an HttpUrlConnection * @summary Cannot flush output stream when writing to an HttpUrlConnection
*/ */
...@@ -158,6 +158,50 @@ public class Test implements HttpHandler { ...@@ -158,6 +158,50 @@ public class Test implements HttpHandler {
exchange.sendResponseHeaders(200, 0); exchange.sendResponseHeaders(200, 0);
} }
break; break;
case 10: /* test11 */
printRequestURI(exchange);
is = exchange.getRequestBody();
s = read (is, str1.length());
error = false;
for (int i=10; i< 30 * 1024; i++) {
byte c = (byte)is.read();
if (c != (byte)i) {
error = true;
System.out.println ("error at position " + i);
}
}
if (!s.equals(str1) ) {
System.out.println ("received string : " + s);
exchange.sendResponseHeaders(500, 0);
} else if (error) {
System.out.println ("error");
exchange.sendResponseHeaders(500, 0);
} else {
exchange.sendResponseHeaders(200, 0);
}
break;
case 11: /* test12 */
printRequestURI(exchange);
is = exchange.getRequestBody();
error = false;
for (int i=10; i< 30 * 1024; i++) {
byte c = (byte)is.read();
if (c != (byte)i) {
error = true;
System.out.println ("error at position " + i);
}
}
if (error) {
System.out.println ("error");
exchange.sendResponseHeaders(500, 0);
} else {
exchange.sendResponseHeaders(200, 0);
}
break;
} }
exchange.close(); exchange.close();
count ++; count ++;
...@@ -390,6 +434,56 @@ public class Test implements HttpHandler { ...@@ -390,6 +434,56 @@ public class Test implements HttpHandler {
} }
} }
static void test11 (String u) throws Exception {
URL url = new URL (u);
System.out.println ("client opening connection to: " + u);
HttpURLConnection urlc = (HttpURLConnection)url.openConnection ();
urlc.setChunkedStreamingMode (36 * 1024);
urlc.setDoOutput(true);
urlc.setRequestMethod ("POST");
OutputStream os = urlc.getOutputStream ();
byte[] buf = new byte [30 * 1024];
for (int i=0; i< 30 * 1024; i++) {
buf[i] = (byte) i;
}
/* write a small bit first, and then the large buffer */
os.write (str1.getBytes());
//os.write (buf, 10, buf.length - 10); /* skip 10 bytes to test offset */
os.write (buf, 10, (10 * 1024) - 10);
os.write (buf, (10 * 1024), (10 * 1024));
os.write (buf, (20 * 1024), (10 * 1024));
os.close();
InputStream is = urlc.getInputStream();
is.close();
int ret = urlc.getResponseCode();
if (ret != 200) {
throw new Exception ("Expected 200: got " + ret);
}
}
static void test12 (String u) throws Exception {
URL url = new URL (u);
System.out.println ("client opening connection to: " + u);
HttpURLConnection urlc = (HttpURLConnection)url.openConnection ();
urlc.setChunkedStreamingMode (36 * 1024);
urlc.setDoOutput(true);
urlc.setRequestMethod ("POST");
OutputStream os = urlc.getOutputStream ();
byte[] buf = new byte [30 * 1024];
for (int i=0; i< 30 * 1024; i++) {
buf[i] = (byte) i;
}
os.write (buf, 10, buf.length - 10); /* skip 10 bytes to test offset */
os.close();
InputStream is = urlc.getInputStream();
is.close();
int ret = urlc.getResponseCode();
if (ret != 200) {
throw new Exception ("Expected 200: got " + ret);
}
}
static com.sun.net.httpserver.HttpServer httpserver; static com.sun.net.httpserver.HttpServer httpserver;
public static void main (String[] args) throws Exception { public static void main (String[] args) throws Exception {
...@@ -411,6 +505,8 @@ public class Test implements HttpHandler { ...@@ -411,6 +505,8 @@ public class Test implements HttpHandler {
test8("http://localhost:"+ port + "/test/test8"); test8("http://localhost:"+ port + "/test/test8");
test9("http://localhost:"+ port + "/test/test9"); test9("http://localhost:"+ port + "/test/test9");
test10("http://localhost:"+ port + "/test/test10"); test10("http://localhost:"+ port + "/test/test10");
test11("http://localhost:"+ port + "/test/test11");
test12("http://localhost:"+ port + "/test/test12");
} finally { } finally {
if (httpserver != null) if (httpserver != null)
httpserver.stop(0); httpserver.stop(0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册