鏈接
一步步學(xué)習(xí)java后臺(tái)(一)
一步步學(xué)習(xí)java后臺(tái)(二)
本期目標(biāo)
1.添加Spring注解支持垃它, 通過注解使得接口可以成功返回一個(gè)字符串
- 添加AccountVo,并將AccountVo轉(zhuǎn)換為JSON數(shù)據(jù)返回
Spring注解
沒有注解的Spring框架是沒有靈魂的捏卓!
上一章中,傳統(tǒng)的SpringMVC的Controller只能完成通過實(shí)現(xiàn)函數(shù) ModelAndView handleRequest()實(shí)現(xiàn)一種方法黍少,此外病曾,在spring-servlet.xml中,我們需要對每一個(gè)controller注冊一個(gè)path钳降。一個(gè)成熟的后臺(tái)出現(xiàn)的路徑可能以千記厚宰,難以想象通過這種手工方式如何實(shí)現(xiàn)。
注解就是為了解決這些問題而實(shí)現(xiàn)的遂填。
@Controller
@Controller注解用于定義Controller
一個(gè)使用@Controller的java類如下:
@Controller注解需要通過scan而被Spring框架發(fā)現(xiàn)固阁,我們在spring-context.xml中添加如下配置:
<context:component-scan base-package="com.zhoushijie.mock">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
@RequestMapping
@Controller + 掃描機(jī)制等同于聲明的 class 屬性,下面我們要配置后半部分的name城菊,也就是 path屬性。
@RequestMapping 就是用來做這種映射的碉克,它可以將請求映射到類上凌唬,也可以映射到方法上。
@Controller
public class HelloWorldJSONController {
@RequestMapping(value = "/hellonihao")
public String helloNiHao() {
return "helloHao";
}
}
這時(shí)候運(yùn)行下漏麦,讓我們來訪問下接口:
http://localhost:8080/tutorial_war_exploded/hellonihao
我們會(huì)發(fā)現(xiàn)客税,這個(gè)接口會(huì)嘗試訪問 helloHao.jsp,但是我們庫里沒有這個(gè)jsp文件撕贞,因此會(huì)爆404
這時(shí)候就需要第三個(gè)注解登場了:
@RequestBody
注解的作用是controller的方法返回的對象通過適當(dāng)?shù)霓D(zhuǎn)換器轉(zhuǎn)換為指定的格式之后更耻,寫入到response對象的body區(qū),通常用來返回JSON數(shù)據(jù)或者是XML數(shù)據(jù)捏膨。
使用此注解之后不會(huì)再走視圖處理器秧均,直接通過response對象輸出指定格式的數(shù)據(jù)。
@Controller
public class HelloWorldJSONController {
@RequestMapping(value = "/hellonihao")
public
@ResponseBody
String helloNiHao() {
return "helloNiHao";
}
}
重新運(yùn)行并訪問号涯,我們就可以看到運(yùn)行結(jié)果:
現(xiàn)在已經(jīng)成功返回字符串?dāng)?shù)據(jù)目胡。
現(xiàn)在,我們已經(jīng)成功完成了第一步返回字符串的目標(biāo)链快。
JSON化
對于后臺(tái)而言誉己,其最主要的職責(zé)是處理邏輯,根據(jù)面向?qū)ο蟮脑瓌t域蜗,邏輯在代碼中的實(shí)現(xiàn)是一個(gè)個(gè)Java Bean巨双。當(dāng)然噪猾,在實(shí)際項(xiàng)目里對應(yīng)不同的目的被稱為VO, PO, DTO..... 前端向后臺(tái)發(fā)起請求,一般是希望獲取到這些Bean (或者叫 VO view object)筑累。而最通用的方法袱蜡,就是講Bean轉(zhuǎn)化為JSON字符串進(jìn)行下發(fā)。
當(dāng)然疼阔,我們可以對每一個(gè)接口函數(shù)添加一次JSON解析戒劫,但是這樣做就浪費(fèi)了Spring框架強(qiáng)大的AOP能力。通過配置婆廊,我們完全可以直接使Bean自動(dòng)JSON化迅细。
對于一個(gè)商業(yè)后臺(tái)系統(tǒng)來說,用戶信息Account是肯定需要的淘邻。因此我們就通過Account例子來進(jìn)行展示:
新建Bean
public class UserAccountVo {
private int userId;
private String sessionKey;
private String headImgUrl;
private String userName;
}
新建Controller
@Controller
@RequestMapping("/account/V1")
public class AccountController {
@RequestMapping(value = "/getUserInfo", method = RequestMethod.GET )
public
@ResponseBody
UserAccountVo getUserInfo() {
UserAccountVo account = new UserAccountVo();
account.setUserId(1);
account.setUserName("userName");
return new UserAccountVo();
}
}
現(xiàn)在我們可以先運(yùn)行一下,看看
git地址:
https://github.com/milawoai/fed-teacher
tag:1.0.3