关于浏览器传递请求中文乱码问题

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/L6_6LXXX/article/details/100549484

关于浏览器传递请求中文乱码问题

原因:

浏览器与服务器使用不同的字符集进行编码与解码

对于不同请求的解决方式:

get:

参数在 请求行 里 默认使用编码方式 ISO-8859-1(此编码不支持中文)
服务器端默认接收时使用字符集:ISO-8859-1

不同版本:

  • Tomcat8及以上版本 目前版本不会乱码

  • Tomcat7及以下版本 可能乱码(中文)

解决方式

new String(参数名.getBytes(“服务器编码”),“传输参数使用的字符集”);

post:

参数在请求体里,使用页面编码(html页面设置的编码格式,没设置默认是GBK)

服务器端默认接收时使用字符集:ISO-8859-1

不同版本:

  • Tomcat目前版本 都可能会出现中文乱码

    解决方式
  1. new String(参数名.getBytes(“服务器编码”),“传输参数使用的字符集”);

    用途:将接收的ISO-8859-1编码格式的数据,以该格式编码,再以传输参数的编码格式进行解码

  2. request.setCharacterEncoding(“传输参数使用的字符集”);

    用途:设置request解码格式

    注意:设置服务器默认解码字符集 针对请求体 放在使用request对象之前

猜你喜欢

转载自blog.csdn.net/L6_6LXXX/article/details/100549484