Servlet请求与相应编解码问题

向浏览器写入数据时乱码问题

  1. 使用字节流向浏览器写入数据
 response.getOutputStream().write("中文".getBytes());
 //此方式向客户端浏览器写入中文,会根据浏览器不同默认解码,决定中文是否乱码
 //解决方案:设置浏览器打开网页时默认的字符集(响应头指定字符集)
 response.setHeader("Content-Type","text/html;charset=UTF-8");
  1. 使用字符流向浏览器写入数据
//此方式一定会乱码,
// 字符流是有缓冲区的,response获得字符流,response设计默认的缓冲区编码是ISO-8859-1。
// 这个字符集不支持中文的。
response.getWriter().println("中文");

//解决:修改缓冲区字符集
response.setCharacterEncoding("UTF-8");
response.setHeader("Content-Type","text/html;charset=UTF-8");
response.getWriter().println("中文");

//字符流向页面响应中文,有一种简化的方式:
//此方法会同时修改缓冲区与浏览器默认打开方式的字符集
response.setContentType("text/html;charset=UTF-8");

读取浏览器数据时乱码问题

  1. POST方式接收中文


// 产生乱码的原因:
// post方式提交的数据是在请求体中,request对象接收到数据之后,放入request的缓冲区中。缓冲区就有编码(默认ISO-8859-1:不支持中文).
//解决方案: 将request的缓冲区的编码修改了即可。
// 设置缓冲区的编码
request.setCharacterEncoding("UTF-8");
String name = request.getParameter("name");
System.out.println("姓名:"+name);
  1. GET方式接收中文
//产生乱码原因:
//get方式提交的数据在请求行的url后面,在地址栏上其实就已经进行了一次URL的编码了。

//解决方案: 将存入到request缓冲区中的值以ISO-8859-1的方式获取到,以UTF-8的方式进行解码。
String name = request.getParameter("name");

String encode = URLEncoder.encode(name, "ISO-8859-1");
String decode = URLDecoder.decode(encode, "UTF-8");
System.out.println("姓名:"+decode);

//简化方式
String value = new String(name.getBytes("ISO-8859-1"),"UTF-8");
System.out.println("姓名:"+value);
``
发布了51 篇原创文章 · 获赞 20 · 访问量 1516

猜你喜欢

转载自blog.csdn.net/qq_39711439/article/details/103533364