从HTTP请求读取非英语UTF-8内容

时间:2018-08-30 06:39:19

标签: java http utf-8 internationalization

我有以下代码。

非英语和UTF-8编码的内容正在请求中。怎么看?目前我正在这样做,但看起来不正确。

私有字符串readContent(HttpServletRequest请求)引发IOException {

String body = null;
BufferedReader reader = null;

if (logger.isDebugEnabled()) {
    logger.debug("Inside readContent() ...");
}

try {
    // Read from request
    StringBuilder buffer = new StringBuilder();
    reader = request.getReader();
    String line;
    while ((line = reader.readLine()) != null) {
        buffer.append(line + "\n");
    }

//  if (body != null) {
        body = buffer.toString();
        body.trim();
//  }

} catch (IOException ex) {
    throw ex;
} finally {
    if (reader != null) {
        try {
            reader.close();
        } catch (IOException ex) {
            throw ex;
        }
    }
}

if (logger.isDebugEnabled()) {
    logger.debug("Leaving readContent() ..." + body);
}
return body;

}

1 个答案:

答案 0 :(得分:0)

我会做类似的事情,并使用Apache Commons IOUtils。您只需要指定编码即可。

InputStream inputStream = request.getInputStream();
String contentAsString = IOUtils.toString(inputStream, "UTF-8"); 

您可以使用try / catch块来处理可能引发的IOException。或者让您的方法抛出一个异常,该异常将在其他地方捕获/处理。