get乱码,post乱码,request.getReader乱码

学习servlet的的时候碰到了这些问题,正好百度之后都解决了问题,但是都比较乱,所以自己总结记录一下:


tomcat使用的编解码是ISO-8859-1

浏览器使用的编解码是URL

我们想要看到的是utf-8

URL的编解码java提供了相应的工具类:

编码:

String name = "张三";
//1、URL编码
String encode = URLEncoder.encode(name,"utf-8");
System.out.println(encode); //%E5%BC%A0%E4%B8%89
//2、URL解码
String decode = URLDecoder.decode(encode,"ISO-8859-1");
System.out.println(decode);//å¼ ä¸
//3、转换为字符串
byte[] bytes = decode.getBytes("ISO-8859-1");
//4、将字节数组转换为字符串
String s = new String(bytes, "utf-8");
System.out.println(s);//张三

里面是不是有你常见的两种乱码呢?哈哈,是的,就是这样。

解决办法:

 doGet()

从浏览器到服务器(打印到控制台):tomcat8以上不用设置编码格式

从服务器响应到了浏览器显示:

response.setContentType("text/html;charset=utf-8");

doPost()

从浏览器到服务器(打印到控制台):

request.setCharacterEncoding("utf-8");

从服务器响应到了浏览器显示:

response.setContentType("text/html;charset=utf-8");

request.getReader()---->URLDecoder.decode(参数,“utf-8”);

 //获取请求体  : 也就是请求参数
 BufferedReader reader = req.getReader();
 String s = reader.readLine();
 s = URLDecoder.decode(s, "utf-8");
 System.out.println(s);

切记要先设置编码格式,再进行逻辑编写。

你可能感兴趣的:(java)