使用SpringMVC響應(yīng)json格式返回的結(jié)果類型
背景:
SpringMVC如何響應(yīng)json格式的數(shù)據(jù)?
技術(shù)實(shí)現(xiàn)
方式1:在Controller使用@RestController注解
方式2:在Controller使用@Controller,在需要返回方法處使用@ResponseBody注解實(shí)現(xiàn)
需要導(dǎo)入j支持的jar包
jackson-annotations-2.2.2.jar
jackson-core-2.2.2.jar
jackson-databind-2.2.2.jar
注意事項(xiàng):
springMVC底層的實(shí)現(xiàn)需要這三個包支持,注意版本,springMVC4.0版本對應(yīng)的包jackson應(yīng)該在2.0以上
方式1:在Controller使用@RestController注解
查看源碼可以看到,@RestController這個注解是一個組合注解:
那么在Controller上使用@RestController,也達(dá)到了@Controller + @ResponseBody的效果;但是,當(dāng)這個controller使用這個注解的時候,要求這個Controller每個方法都返回json格式的字符串!
如果開發(fā)的是第三方口,則會使用這個注解進(jìn)行開發(fā)。
@RestController//所有的方法都需要返回json格式的字符串 public class ProductController { @RequestMapping("queryAll.do") public List<Product> queryAll() { //模擬數(shù)據(jù) List<Product> products = new ArrayList<>(); for (int i = 1; i <= 10; i++) { Product p = new Product(i, "name" + i); products.add(p); } return products; } }
使用Postman查看結(jié)果:
方式2:在Controller使用@Controller
在需要返回方法處使用@ResponseBody注解實(shí)現(xiàn)
使用這樣的組合注解,Controller中的方法返回值可以靈活。不僅限于json格式的字符串。
@Controller public class ProductController { @RequestMapping("queryAll.do") @ResponseBody // 這個注解放在方法上,目的是把該方法的返回值轉(zhuǎn)換成json格式的字符串 public List<Product> queryAll() { //模擬數(shù)據(jù) List<Product> products = new ArrayList<>(); for (int i = 1; i <= 10; i++) { Product p = new Product(i, "name" + i); products.add(p); } return products; } }
三種方式實(shí)現(xiàn)SpringMVC返回json數(shù)據(jù)
1、第一種方式
是spring2時代的產(chǎn)物,也就是每個json視圖controller配置一個Jsoniew。
如:
<bean id="defaultJsonView" class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"/>
或者
<bean id="defaultJsonView" class="org.springframework.web.servlet.view.json.MappingJackson2JsonView"/>
同樣要用jackson的jar包。
2、第二種方式
使用JSON工具將對象序列化成json,常用工具Jackson,fastjson,gson。
利用HttpServletResponse,然后獲取response.getOutputStream()或response.getWriter()直接輸出。
示例:
public class JsonUtil { private static Gson gson=new Gson(); /** * @MethodName : toJson * @Description : 將對象轉(zhuǎn)為JSON串,此方法能夠滿足大部分需求 * @param src * :將要被轉(zhuǎn)化的對象 * @return :轉(zhuǎn)化后的JSON串 */ public static String toJson(Object src) { if (src == null) { return gson.toJson(JsonNull.INSTANCE); } return gson.toJson(src); } }
3、第三種方式
利用spring mvc3的注解@ResponseBody
例如:
@ResponseBody @RequestMapping("/list") public List<String> list(ModelMap modelMap) { String hql = "select c from Clothing c "; Page<Clothing> page = new Page<Clothing>(); page.setPageSize(6); page = clothingServiceImpl.queryForPageByHql(page, hql); return page.getResult(); }
然后使用spring mvc的默認(rèn)配置就可以返回json了,不過需要jackson的jar包哦。
注意:當(dāng)springMVC-servlet.xml中使用<mvc:annotation-driven />時,如果是3.1之前已經(jīng)默認(rèn)注入AnnotationMethodHandlerAdapter,3.1之后默認(rèn)注入RequestMappingHandlerAdapter只需加上上面提及的jar包即可!
如果是手動注入RequestMappingHandlerAdapter 可以這樣設(shè)置
配置如下:
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter" p:ignoreDefaultModelOnRedirect="true" > <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"/> </list> </property> </bean>
添加包
jackson-mapper-asl-*.jar
jackson-core-asl-*.jar
可以看出,使用方式越來越簡單,程序員越來越傻,不知道是好事,還是壞事……以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
java使用DelayQueue實(shí)現(xiàn)延時任務(wù)
項(xiàng)目中經(jīng)常會用到類似一些需要延遲執(zhí)行的功能,比如緩存,java提供了DelayQueue來很輕松的實(shí)現(xiàn)這種功能,下面小編就來和大家介紹一下如何使用DelayQueue實(shí)現(xiàn)延時任務(wù)吧2023-10-10實(shí)現(xiàn)一個規(guī)則引擎的可視化具體方案
項(xiàng)目原因需要用到規(guī)則引擎,但是發(fā)現(xiàn)大部分不可以自由的進(jìn)行規(guī)則定義,通過不斷嘗試變換關(guān)鍵字在搜索引擎搜索,最終在stackoverflow找到了一個探討這個問題的帖子,特此將帖子中提到的方案分享一下,如果你跟我一樣在研究同樣的問題,也許對你有用2021-04-04利用線程實(shí)現(xiàn)動態(tài)顯示系統(tǒng)時間
編寫Applet小程序,通過在HTML文檔中接收參數(shù),顯示當(dāng)前的系統(tǒng)時間,需要的朋友可以參考下2015-10-10JFreeChart實(shí)現(xiàn)實(shí)時曲線圖
這篇文章主要為大家詳細(xì)介紹了JFreeChart實(shí)現(xiàn)實(shí)時曲線圖的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06

idea每次新打開的項(xiàng)目窗口maven都要重新設(shè)置問題