post请求下 SpringJDBC中文乱码问题,配置CharacterEncodingFilter后依然乱码的问题解决

问题描述:

最近在学习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>

问题解决。这问题真的是找了好久解决办法,因此记录一下。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值