应用环境spring3.* 使用spring 自己的mvc。
当从控制器返回中文字符串或者json对象给前台的时候,发现Debug控制台输出的字符集都是默认采用的spring自己的iso-8859-1。
参考网上各位“猿友”的解决方案,归纳起来感觉一下两种方式使用起来较为合适。
1、配置文件增加
<mvc:annotation-driven> <mvc:message-converters> <bean class="org.springframework.http.converter.StringHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>application/json;charset=UTF-8</value> </list> </property> </bean> </mvc:message-converters> </mvc:annotation-driven>
2、在控制器的@RequestMapping重置参数produces
例如:@RequestMapping(params="in",produces = "application/json; charset=UTF-8")
这里只是针对json格式做了说明,其实上下文的类型可以替换 比如使用"text/plain"替换"application/json"
上述方式 都是基于将json对象toString,spring针对json还是可以在配置文件里面配置视图响应
<!-- 根据Controller返回的视图名称,找对应ID的view bean进行响应 -->
<bean class="org.springframework.web.servlet.view.BeanNameViewResolver" p:order="1"/>
<!-- 根据客户端的不同的请求决定不同的view进行响应, 如 /user/{userid}.json /user/{userid}.xml -->
<bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
<property name="order" value="2" />
<!-- 是否忽略掉Accept Header,默认false,例如:
GET /user/{userid} HTTP/1.1 Accept:application/json
-->
<property name="ignoreAcceptHeader" value="true" />
<!-- 是否启用扩展名支持,默认true,例如 /user/{userid}.json -->
<property name="favorPathExtension" value="true"></property>
<!-- 是否启用参数支持,默认true,例如 /user/{userid}?format=json -->
<property name="favorParameter" value="false" />
<!-- 扩展名至mimeType的映射,即 /user.json => application/json -->
<property name="mediaTypes">
<map>
<entry key="json" value="application/json" />
<entry key="xml" value="application/xml" />
</map>
</property>
<!-- 在没有扩展名时即: "/user/1" 时的默认展现形式 -->
<property name="defaultContentType" value="text/html" />
<property name="viewResolvers">
<list>
</list>
</property>
<property name="defaultViews">
<list>
<ref local="jsonview"/>
<ref local="xmlview"/>
</list>
</property>
</bean>
<!-- view rander for application/json -->
<bean id="jsonview" class="org.springframework.web.servlet.view.json.MappingJacksonJsonView" />
<!-- view rander for application/xml -->
<bean id="xmlview" class="org.springframework.web.servlet.view.xml.MarshallingView" >
<property name="marshaller">
<bean class="org.springframework.oxm.xstream.XStreamMarshaller">
<property name="autodetectAnnotations" value="true"/>
</bean>
</property>
</bean>
这样 我们在控制器的响应方法中不需要再添加@ResponseBody这个注解,
@RequestMapping(params="in")
public String login(ModelMap model,HttpServletRequest request,
HttpServletResponse response){
JSONObject result = new JSONObject();
String username = request.getParameter("username");
String pwd = request.getParameter("pwd");
String yzm = request.getParameter("yzm");
String msg = null;
if(username==null || "".equals(username)){
result.put("msg", "用户名为空");
}else{
System.out.println("前台传入的username:"+username+" ; pwd:"+pwd);
msg = basicInfoService.checkUserPwd(username, pwd);
}
if(msg!=null){
result.put("type", "fail");
result.put("msg", msg);
}else{
result.put("type", "success");
request.getSession().setAttribute("username", username);
request.getSession().setAttribute("username_sign", MD5.encryptLowerCase(username));
}
model.put("result", result);
return "jsonview";
// return result.toString();
}
方法最后返回的对应到配置文件中“<ref local="jsonview"/>” ,当然 这还需要在方法中将需要生成json对象的bean放到ModelMap中“model.put("result", result);”
前台就会获得一个
{"result":{"type":"fail","msg":"用户名或密码不正确"}}
这样的对象。
以上算是迷迷糊糊写出来的东西,方便以后自己再找来看看,获取还有更好更稳妥的方式,慢慢发掘吧。
最后还是要说,尽管spring不断改进不断简化配置文件,但还是深深的感觉spring的配置深似海……