摘自Wikipedia: REST风格的体系结构由客户端和服务器组成。 客户端向服务器发起请求; 服务器处理请求并返回适当的响应。 请求和响应围绕资源表示的传递而构建。 资源本质上可以是可以解决的任何连贯且有意义的概念。
对于那些从未了解过Rest的人来说,对Rest体系结构的这种描述似乎有些奇怪并且有些复杂。
让我们从使用Spring MVC模板创建的简单Spring MVC应用程序开始。 这里没有什么秘密,您将拥有一个servlet-context.xml ,其中注册了component-scan , 注解驱动和InternalResourceViewResolver 。
<?xml version="1.0" encoding="UTF-8" ?>
<beans:beans xmlns="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:beans="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:util="http://www.springframework.org/schema/util" xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"><!-- DispatcherServlet Context: defines this servlet's request-processing infrastructure --> <!-- Enables the Spring MVC @Controller programming model --> <annotation-driven /> <!-- Resolves views selected for rendering by @Controllers to .jsp resources in the /WEB-INF/views directory --> <beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><beans:property name="prefix" value="/WEB-INF/views/" /> <beans:property name="suffix" value=".jsp" /> </beans:bean><context:component-scan base-package="org.springframework.rest" />
</beans:beans>
下一步是定义Character类。 具有四个属性的简单POJO 。 使用Jaxb批注将类转换为其XML表示 形式 。 Jaxb允许开发人员将Java类映射到XML表示,反之亦然。
package org.springframework.rest;import java.net.URL;import org.codehaus.jackson.annotate.JsonAutoDetect;@XmlRootElement
public final class Character {private int id;private String name;private boolean isHuman;private URL characterUrl;protected Character() {}public Character(int id, String name, boolean isHuman, URL characterUrl) {super();this.id = id;this.name = name;this.isHuman = isHuman;this.characterUrl = characterUrl;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public boolean isHuman() {return isHuman;}public void setHuman(boolean isHuman) {this.isHuman = isHuman;}public URL getCharacterUrl() {return characterUrl;}public void setCharacterUrl(URL characterUrl) {this.characterUrl = characterUrl;}@Overridepublic int hashCode() {final int prime = 31;int result = 1;result = prime * result + id;return result;}@Overridepublic boolean equals(Object obj) {if (this == obj)return true;if (obj == null)return false;if (getClass() != obj.getClass())return false;Character other = (Character) obj;if (id != other.id)return false;return true;}}
最后是Spring MVC中最重要的类“ 控制器 ”。 控制器将负责实施角色资源所需的操作。 在当前情况下,仅实现GET ,其他操作将类似。 让我们看一下代码:
@Controller
public class HomeController {private static final Map<Integer, Character> characters = new HashMap<Integer, Character>();static {try {characters.put(1, new Character(1, "Totoro", false, new URL("http://animeonly.org/albums/VISINAUJI/EGIO/fourth/Mon-Voisin-Totoro/normal_totoro_001.jpg")));characters.put(2, new Character(2, "Satsuki Kusakabe", true, new URL("http://profile.ak.fbcdn.net/hprofile-ak-ash2/48980_1802552968_7286_n.jpg")));characters.put(3, new Character(3, "Therru", false, new URL("http://28.media.tumblr.com/tumblr_lj4ctjKA8Y1qdvyqpo1_400.jpg")));} catch (MalformedURLException e) {e.printStackTrace();}}/*** Simply selects the home view to render by returning its name.*/@RequestMapping(value = "/characters/{characterId}", method = RequestMethod.GET)@ResponseBodypublic Character findCharacter(@PathVariable int characterId) {return characters.get(characterId);}}
第一部分是存储所有字符的地图。 我使用这种方法来不专注于数据访问。 然后,当URI是/ characters / {characterId }时调用的findCharacter方法。 这是一个URI模板,是一个类似URI的字符串,包含一个或多个变量名,可以使用@PathVariable批注进行访问。 因此,当您访问/ characters / 1参数时, characterId绑定为1。
最后一个重要部分是@ResponseBody批注。 该注释可以放在方法上,并指示返回类型应直接写到HTTP响应主体,而不是放置在Model中 ,或解释为视图名称,这是Spring MVC的标准行为。 因此findCharacter方法返回一个Character对象。
这就是您执行此代码的全部,例如,您输入URI http:// localhost:8080 / RestServer / characters / 1 ,输出(使用RestClient UI )将是:
现在是您想知道的时候,如果我返回一个Character对象,并且输出是XML ,则object和XML之间的转换在哪里? 如此简单,让我介绍一个新概念: HttpMessageConverters 。 HttpMessageConverter负责从HTTP请求消息转换为对象,以及从对象转换为HTTP响应主体。 默认情况下,接下来注册HttpMessageConverters :
结论
当然,这是一个非常简单的应用程序,仅需一个操作,但是它为您提供了如何使用Spring MVC开发Restful Web服务的想法。 使用与GET相同的方法来编写所有必需的操作只是时间问题。
在这一点上,我认为我们所有人都得出了相同的结论。 批注确实非常强大, Spring MVC非常适合开发RESTful Web服务。
下次见...
下载代码。
参考:在One Jar To Rule Them All博客中, 使用我们的JCG合作伙伴 Alex Soto 使用Spring MVC开发Restful Web服务 。
相关文章 :
- jqGrid,REST,AJAX和Spring MVC集成
- Java RESTful API集成测试
- 使用Spring 3.1和基于Java的配置构建RESTful Web服务,第2部分
- 重审Gson的Android JSON解析
- Tomcat 7上具有RESTeasy JAX-RS的RESTful Web服务-Eclipse和Maven项目
- Spring3 RESTful Web服务
- Spring MVC开发–快速教程
翻译自: https://www.javacodegeeks.com/2011/12/develop-restful-web-services-using.html