寫在前面
- 重要學(xué)習(xí)原理
- 先看官方文檔剩辟,然后可以搜索博客加以配合
Restful 簡介
全稱REpresentational State Transfer的縮寫灵巧。是基于 WEB標(biāo)準(zhǔn)的軟件架構(gòu),使用HTT協(xié)議處理數(shù)據(jù)通信抹沪。以資源為中心刻肄,其中每個(gè)組成部分都是一個(gè)資源,并且資源通過使用 HTTP 標(biāo)準(zhǔn)方法的公共接口訪問融欧。EST 由 Roy Fielding 在 2000 年首次提出敏弃。
參考
- Jersy 官方文檔
- jersey+maven構(gòu)建restful服務(wù)--入門篇
- 業(yè)余參考 Spring的技術(shù)支持
- 它山之石 NodeJs Restful
- RESTful API 設(shè)計(jì)最佳實(shí)踐
操作步驟(本次是以jersy為主)
先決條件 安裝好maven
- 運(yùn)行mvn下載jersy官方的web app骨架
mvn archetype:generate -DarchetypeArtifactId=jersey-quickstart-webapp -DarchetypeGroupId=org.glassfish.jersey.archetypes -DinteractiveMode=false -DgroupId=com.example -DartifactId=simple-service-webapp -Dpackage=com.example -DarchetypeVersion=2.26
User.java
package com.example;
import java.io.Serializable;
public class User implements Serializable{
private static final long serialVersionUID = 1L;
private int id;
private String name;
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + "]";
}
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 User() {
super();
}
}
RestfulHelloWorld.java
package com.example;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.MediaType;
@Path("/helloworld")
public class RestfulHelloWorld {
@GET
@Produces(MediaType.TEXT_PLAIN)
public String sayHelloWorld() {
return "Hello World!";
}
@GET
@Path("/{param}")
@Produces("text/plain;charset=UTF-8")
public String sayHello2UserByText(@PathParam("param") String username) {
return "Hello " + username;
}
@GET
@Path("/get")
@Produces(MediaType.APPLICATION_JSON)
public User sayHelloToUserByJson(@QueryParam("username") String username) {
User user = new User();
user.setId(1);
user.setName(username);
return user;
}
}
3 .結(jié)果
1.png
記錄:
骨架自帶的web.xml, 骨架配置了掃描包
<?xml version="1.0" encoding="UTF-8"?>
<!-- This web.xml file is not required when using Servlet 3.0 container,
see implementation details http://jersey.java.net/nonav/documentation/latest/jax-rs.html -->
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<servlet>
<servlet-name>Jersey Web Application</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>com.example</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey Web Application</servlet-name>
<url-pattern>/webapi/*</url-pattern>
</servlet-mapping>
</web-app>