栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

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

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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);

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/830052.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号