解决SpringMvc后台接收json数据中⽂乱码问题的⼏种⽅法1、使⽤ajax从前台页⾯传输数据到后台controller控制器的时候,出现中⽂乱码(问号)。
之前在⽹上了各种解决⽅案,都⾏不通,最后发现是tomcat服务器接收数据的问题
解决⽅案:
⽅式⼀:在controller接收参数时,对参数进⾏转码
@ResponseBody
@RequestMapping(value="/getJsonDataByCityName",produces="application/json")
public String getJsonByName(HttpServletRequest request,HttpServletResponse response,@RequestParam String city_name)throws ServletException,IOException {
//response.setContentType("text/html;charset=UTF-8");
//request.setCharacterEncoding("UTF-8");//解决post乱码问题
System.out.CharacterEncoding());
city_name = new String(Bytes("ISO-8859-1"), "UTF-8");
System.out.println("city_name:"+city_name);
}
⽅式⼆:
配置tomcat⽬录下的l⽂件
tomcat7/l
给该⾏代码加上 URIEncoding="UTF-8" 的编码属性
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8" />
原因分析:
其实乱码问题出现的原因,就是由于默认的tomcat配置,接收请求是以ISO-8859-1来转码,导致中⽂出现了乱码问题,只要能正确的以utf-8来转码,则可以解决乱码问题。
2、普通数据传输,从jsp页⾯传到后台controller,中⽂乱码问题解决⽅案
param name(1)、⾸先检查jsp页⾯编码格式是否是utf-8
(2)、设置中⽂过滤
<!-- 中⽂编码 -->
<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>
(3)、springMvc配置⽂件中设置JSON数据转换
<mvc:annotation-driven>
<mvc:message-converters register-defaults="true">
<!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射注解请求映射
默认是ISO-88859-1,避免乱码这⾥设置为UTF-8 -->
<bean class="org.verter.StringHttpMessageConverter">
<property name="supportedMediaTypes" value="text/html;charset=UTF-8" />
</bean>
<!-- 启动JSON格式的配置,⾃动将格式转换成JSON格式,不需要其他类 -->
<bean id="jacksonMessageConverter" class="org.verter.json.MappingJacksonHttpMessageConverter">
<property name="supportedMediaTypes" value="application/json;charset=UTF-8" />
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论