问题描述:
最近在学习spring框架,在做demo的时候,发现往数据库中添加信息再返回后jsp页面显示如下图所示乱码:
于是,我就上网搜索解决办法,网上给出解决办法是在web.xml
文件下加解决乱码的过滤器,代码如下:
<!-- 解决乱码的过滤器-->
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
但是添加完上述代码后,返回的信息由乱码变成了?,如下图所示:
可以看到,数字和字母是可以正常显示的,因此还存在问题。
继续搜索解决办法,发现网上大佬说原因是因为tomcat配有配置编码格式,server.xml里如果不配置编码格式,则默认是iso-8859-1,于是进行如下修改问题解决:
博主是MacBook,因此说的是MacBook下的配置文件位置
打开自己下载的tomcat文件夹下的conf文件下的server.xml文件,在69行左右,将Connector属性更改如下:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
URIEncoding="UTF-8"/>
发现,还是返回的数据还是?所以问题还没有解决。
原因分析:
由于博主是初学者,不太了解工作过程,这里原因就不分析了,留个坑,以后博主成为大神再来解决,或者读者有大神也可以解答一下。
下面直接放解决方案。
解决方案:
打开spring配置文件applicationContext.xml,配置数据源的代码由:
<!-- 加载jdbc.properties,通过 context加载-->
<context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder>
<!-- 配置数据源对象-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}"></property>
<property name="jdbcUrl" value="${jdbc.url}"></property>
<property name="user" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
更改成:
<!-- 加载jdbc.properties,通过 context加载-->
<context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder>
<!-- 配置数据源对象-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}"></property>
<property name="jdbcUrl" value="${jdbc.url}?characterEncoding=utf-8"></property>
<property name="user" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
<property name="jdbcUrl" value="${jdbc.url}?characterEncoding=utf-8"></property>
问题解决。这问题真的是找了好久解决办法,因此记录一下。