SpringMVC - 多情景处理乱码问题

1.页面乱码

页面相对是最为容易解决的,往往是在相应的jsp页面或者html页面设置相关的字符集即可。如

<%@page language= "java"  contentType= "text/html; charset=utf-8"
     pageEncoding= "utf-8" %>

 

 

2.传值乱码

2.1 官方解决方案

在传值过程中,也是乱码出现的频繁地。官方的解决方案是在web.xml中,配置指定的filter:

注意:这里必须是/* (既过滤请求,又包含所有jsp页面),不能是/(只过滤请求罢辽),否则依旧乱码。

 

 完整配置:

 

2.2 设置request字符集

往往从前台传入到对应的controller或者是action之后出现乱码,讲讲我一般的思路是先打印request本身默认的字符集

System.out.println(request.getCharacterEncoding());

接着按照情况,如果打印的不是所需要的字符集则设置相应字符集即可

request.setCharacterEncoding( "UTF-8" );

当然某种情况可能还是无法解决这时候用以下这个即可:

String str=newString((request.getParameter( "bigQuestionTypeName" )).getBytes( "iso-8859-1" ), "utf-8" )

 

3.存入数据库乱码

这个相对就比较复杂,这里lz用的mysql,且以mysql来介绍如何来解决这个乱码问题。

大家都知道,无论是底层使用的是纯粹的jdbc还是hibernate还是jpa都好,其实本质上都是jdbc,对应的框架只不过在相关的基础上进行特定的封装。所以无论是什么样的技术,都会用到连接到数据库的url。所以url首先是需要检查的。

3.1检查JDBC的url

标准情况会在相应的后面加上相应的字符集设置,如下

jdbcUrl = jdbc:mysql:///itcastoa?useUnicode= true &characterEncoding=UTF-8

如上,useUnicode就不用说了,连接数据库中设置的字符集,&amp这是什么的?这就有问题了,在xml中&amp是&的转义字符。如果你是用xml来配置对应的数据库连接配置的话就什么问题了。但是如果用的是**.properties就有问题了,则必须将amp除去即可。这个确实是lz经历了头破血流的经验啊。

 

3.2检查数据库设置

详见:https://blog.csdn.net/qq_35970872/article/details/78517096

 

4.参考文献

https://blog.csdn.net/qq_35970872/article/details/78517096

 

posted on 2020-12-03 22:43  frank_cui  阅读(101)  评论(0编辑  收藏  举报

导航

levels of contents