关于ajax从spring mvc后台取值 返回值乱码问题

本文介绍如何在SpringMVC中正确配置JSON数据交互,确保前后端数据传递采用UTF-8编码,避免乱码问题,并展示了具体的配置代码及注解使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!-- 返回json 方法二 需要导入 jackson-annotations.jar,jackson-core.jar,jackson-databind.jar  必须放在annotation-driven 因为会自动注册 而springmvc默认使用iso-8859-1-->  
    <!-- <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" />
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
        <property name="messageConverters">
            <list>
                <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                    <property name="supportedMediaTypes">
                        <list>
                            <value>text/html; charset=UTF-8</value>
                            <value>application/json;charset=UTF-8</value>
                        </list>
                    </property>
                </bean>
                <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
                    <property name="supportedMediaTypes">
                        <list>
                            <value>text/html; charset=UTF-8</value>
                            <value>application/json;charset=UTF-8</value>
                        </list>
                    </property>
                </bean>
            </list>
        </property>
    </bean> -->
     

<!--扩充了注解驱动,可以将请求参数绑定到控制器参数(开启注解)-->

    <mvc:annotation-driven />



在spring mvc的配置文件中 添加上述代码 注意  messageconverter转换器一定要放在annotation-driven前面 不然会自动注册spring mvc默认使用iso-8859-1 这里实测是可以使用的  但是楼主还使用了vue.js 目前还不清楚为什么这样配置后vue.js获取到的json数据无法显示在网页的情况  所以暂时用这样的形式来代替


@RequestMapping(value="/checkSession",produces="text/html;charset=UTF-8") //设置返回类型为utf-8  spring-mvc默认是iso-8859-1
public @ResponseBody String checkSession(){
String status = stageLoginService.checkSession();
return status;
}


这里的produces是设置返回类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值