向响应体中写入字节数组,后获取HttpUrlconnection的输入流,读取的数据不再是字节数组了,为什么,怎么解决
时间: 2024-09-14 15:03:07 浏览: 43
当你通过`HttpURLConnection`向服务器发送请求,并向响应体中写入字节数组之后,然后尝试从其输入流中读取数据,可能会遇到预期不是字节数组的情况。这通常是因为`HttpURLConnection`会自动解码接收到的内容,比如如果服务器返回的是UTF-8编码的文本内容,那么读取到的就是字符串而不是原始字节。
这是因为`HttpURLConnection`内部有一个默认的输入流解析机制,它会根据响应头的`Content-Type`字段自动识别并处理数据格式。例如,如果`Content-Type`标明为`text/plain`,那么它会将接收到的数据作为文本进行解析,而不是保持原始字节状态。
如果你希望直接得到字节数组而不进行自动解码,你需要采取特定的方式手动处理:
1. **关闭自动解码**:设置连接的输入流为字节输入流(InputStream),可以使用`setDoInput(true)`和`setUseCaches(false)`来避免自动解码。示例:
```java
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoInput(true);
conn.setRequestProperty("Accept-Encoding", "identity");
conn.connect();
```
2. **手动读取字节**:创建一个新的字节数组输入流(ByteArrayInputStream)来读取HTTP连接的输入流内容:
```java
InputStream inputStream = conn.getInputStream();
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
byte[] buffer = new byte[4096];
int read;
while ((read = inputStream.read(buffer)) != -1) {
outputStream.write(buffer, 0, read);
}
byte[] responseBytes = outputStream.toByteArray();
```
这样,你就得到了服务器返回的原始字节数组。
阅读全文