成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Springboot整合Jersey實現REST full風格API及原理

開發 前端
Jersey對掃描可執行檔案的支持相當有限。例如,當運行一個可執行的war文件時,它不能掃描在完全可執行的jar文件或WEB-INF/classes中找到的包中的端點。

概述

Jersey RESTful 框架是開源的RESTful框架, 實現了JAX-RS (JSR 311 & JSR 339) 規范。它擴展了JAX-RS 參考實現, 提供了更多的特性和工具, 可以進一步地簡化 RESTful service 和 client 開發。盡管相對年輕,它已經是一個產品級的 RESTful service 和 client 框架。與Struts類似,它同樣可以和hibernate,spring框架整合。

jersey1.X使用的是sun的com.sun.jersey

jersey2.X使用的是glassfish的org.glassfish.jersey

Jersey與JAX-RS的關系:

Jersey是一個框架,實現了restful風格;JAX-RS也實現了restful風格。那么Jersey與JAX-RS是什么關系呢?我們可以這樣理解:JAX-RS是java自己的一個小的框架,實現了restful風格,只不過功能不是很強大;而Jersey呢,它是一個比較成熟的restful框架了,它在設計的時候,是基于JAX-RS的,它使用了java的JAX-RS的一些注解,當然了,他也有自己的特有注解,以及其他更強大的功能。

如果你更喜歡REST端點的JAX-RS編程模型,則可以使用可用的實現之一,而不是Spring MVC。Jersey和Apache CXF開箱即用就可以很好地工作。CXF要求你在應用程序上下文中將其Servlet或過濾器注冊為@Bean。Jersey原生支持Spring,所以我們在Spring Boot中也為它提供了自動配置支持,還有一個starter。

要開始使用Jersey,需要把spring-boot-starter-jersey作為依賴,然后需要一個ResourceConfig類型的@Bean,用來注冊所有端點,如下面的例子所示:

示例:?

@Component
public class MyJerseyConfig extends ResourceConfig {
public MyJerseyConfig() {
register(MyEndpoint.class);
}
}

Jersey對掃描可執行檔案的支持相當有限。例如,當運行一個可執行的war文件時,它不能掃描在完全可執行的jar文件或WEB-INF/classes中找到的包中的端點。為了避免這種限制,不應該使用packages方法,而應該使用register方法單獨注冊端點,如上例所示。

對于更高級的定制,你還可以注冊任意數量實現了ResourceConfigCustomizer的bean。所有注冊的Endpoint都應該是帶有HTTP資源注解的@Components (@GET等),如下面的例子所示:?

@Component
@Path("/hello")
public class MyEndpoint {
@GET
public String message() {
return "Hello";
}
}

JAX-RS注解

一、@Path

一個Java類要能夠處理REST請求,則這個類必須至少添加一個@Path("/")的注解;對于方法,這個注解是可選的,如果不添加,則繼承類的定義。

@Path里的值可以是一個復雜的表達式,例如@Path("/{id}") ,其中 {id}表達式表示一個路徑請求的一部分。

@Path也支持正則表達式,例如: @Path("{id: \\d+}") ,其中 \\d+ 表示一個數字。

二、@Method

一個方法上只有添加了某個Http Method的注解,例如@GET,才會生效。

對于資源的具體操作類型,由HTTP動詞表示。

常用的HTTP動詞有下面五個:

GET(SELECT):從服務器取出資源(一項或多項)

POST(CREATE):在服務器新建一個資源

PUT(UPDATE):在服務器更新資源(客戶端提供改變后的完整資源)

PATCH(UPDATE):在服務器更新資源(客戶端提供改變的屬性)

DELETE(DELETE):從服務器刪除資源

還有兩個不常用的Method。

HEAD:獲取資源的元數據

OPTIONS:一般由瀏覽器自動發起,用于描述目標資源的通信選項。

下面是一些例子:

GET /uses:列出所有用戶

POST /users:新建用戶

GET /users/ID:獲取指定id用戶的信息

PUT /users/ID:更新指定id用戶的信息

PATCH /users/ID:更新指定id用戶的信息

DELETE /users/ID:刪除指定id用戶

GET /users/ID/addresses:列出指定id用戶的所有住址信息

DELETE /users/ID/addresses/ID:刪除指定id用戶下的指定地址id信息

三:Accept和Content-Type的區別

Accept就表示接口要返回給客戶端的數據格式,

Content-Type表示客戶端發送給服務器端的數據格式。

四:@Produces

定義資源類或javax.ws.rs.ext.MessageBodyWriter的方法可以生成的媒體類型。如果沒有指定,那么容器將假定可以生成任何類型。方法級注釋覆蓋類級注釋。容器負責確保調用的方法能夠生成HTTP請求中請求的一種媒體類型。如果沒有這樣的方法可用,容器必須以RFC 2616指定的HTTP“406 Not accepted”作為響應。

有幾種格式如下:

@Produces("text/plain") 文本類型

@Produces("text/html") Html類型

@Produces({"application/xml"}) Xml類型

@Produces({ "application/json"}) Json類型

可以一次注解兩種或多種的MIME類型,格式如:{"application/xml", "application/json"}這表示兩者都可以使用,但是選擇的時候一般會選擇前者,即application/xml,因為它第一次出現。

五:@Consumes

定義資源類或javax.ws.rs.ext.MessageBodyReader的方法可以接受的媒體類型。如果沒有指定,容器將假定任何媒體類型都是可接受的。方法級注釋覆蓋類級注釋。容器負責確保所調用的方法能夠使用HTTP請求實體的媒體類型。如果沒有這樣的方法可用,容器必須按照RFC 2616的規定,以HTTP“415 Unsupported Media Type”作為響應。

六:@QueryParam與@PathParam區別

@QueryParam:指定的是URL中的參數是以鍵值對的形式出現的,而在程序中

@QueryParam("id") Integer id獲取請求參數id

如:URL輸入為:/api/users?id=1

@PathParam:參數作為路徑的一部分

如:/api/users/1

Jersey詳細配置

在SpringBoot中引入如下依賴?

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jersey</artifactId>
</dependency>

引入上面的依賴后,接下來我們只需要定義繼承ResourceConfig類型的Bean即可。Jersey的自動配置其中有一個條件就是當前的CLASSPATH中有ResourceConfig類型的Bean才生效,如下:?

@Configuration(proxyBeanMethods = false)
@ConditionalOnBean(type = "org.glassfish.jersey.server.ResourceConfig")
@EnableConfigurationProperties(JerseyProperties.class)
public class JerseyAutoConfiguration implements ServletContextAware {
}

其中@ConditionalOnBean條件限制了只有當前容器中有ResourceConfig類型的Bean該自動配置才會生效。

注冊繼承ResourceConfig后請求又是如何被匹配的?

當上面的自動配置生效后,默認情況下會注冊一個Servlet:?

public class JerseyAutoConfiguration implements ServletContextAware {
@Bean
@ConditionalOnMissingBean
public JerseyApplicationPath jerseyApplicationPath() {
return new DefaultJerseyApplicationPath(this.jersey.getApplicationPath(), this.config);
}
@Bean
@ConditionalOnMissingBean(name = "jerseyFilterRegistration")
@ConditionalOnProperty(prefix = "spring.jersey", name = "type", havingValue = "filter")
public FilterRegistrationBean<ServletContainer> jerseyFilterRegistration(JerseyApplicationPath applicationPath) {
FilterRegistrationBean<ServletContainer> registration = new FilterRegistrationBean<>();
registration.setFilter(new ServletContainer(this.config));
// ...
return registration;
}
@Bean
@ConditionalOnMissingBean(name = "jerseyServletRegistration")
@ConditionalOnProperty(prefix = "spring.jersey", name = "type", havingValue = "servlet", matchIfMissing = true)
public ServletRegistrationBean<ServletContainer> jerseyServletRegistration(JerseyApplicationPath applicationPath) {
ServletRegistrationBean<ServletContainer> registration = new ServletRegistrationBean<>(
new ServletContainer(this.config), applicationPath.getUrlMapping());
addInitParameters(registration);
registration.setName(getServletRegistrationName());
registration.setLoadOnStartup(this.jersey.getServlet().getLoadOnStartup());
return registration;
}
}

上面列出了Filter及Servlet,根據上面的配置知道,在沒有手動在配置文件中設置spring.jersey.type=filter,那么默認就是servlet生效。

向容器注冊了ServletContainer Servlet程序,該Servlet程序傳入了自定義的ResourceConfig及默認的該Servlet請求Mapping地址默認是/*。

ServletContainer

該Servlet傳入了ResourceConfig:?

public class JerseyAutoConfiguration implements ServletContextAware {
// 通過構造函數注入ResourceConfig類型的Bean
private final ResourceConfig config;
public JerseyAutoConfiguration(JerseyProperties jersey, ResourceConfig config,
ObjectProvider<ResourceConfigCustomizer> customizers) {
this.jersey = jersey;
this.config = config;
customizers.orderedStream().forEach((customizer) -> customizer.customize(this.config));
}
}

個性化配置ResourceConfig

要想個性化定制配置,可以注冊任意數量的實現ResourceConfigCustomizer的bean。?

@Component
public class CustomResourceConfigCustomizer implements ResourceConfigCustomizer {

@Override
public void customize(ResourceConfig config) {
// 個性化定制配置
}

}

配置應用請求路徑

@Component
// 添加此注解所有的api接口都需要添加/api前綴
@ApplicationPath("/api")
public class JerseyConfig extends ResourceConfig {
}

配置文件方式?

spring:
jersey:
type: servlet
# 該配置會覆蓋@ApplicationPath
application-path: /api-a

示例:?


@Component
@Path("/users")
public class UserEndpoint {

@Path("/{id}")
@GET
@Produces({"application/json"})
public User queryUser(@PathParam("id") Integer id) {
return new User(id, "姓名 - " + id, 6 + id) ;
}

}

完畢!!!

責任編輯:武曉燕 來源: 實戰案例錦集
相關推薦

2011-10-27 16:24:48

API

2010-01-08 12:03:42

ibmdwREST

2022-03-29 09:00:00

Angular框架REST API

2025-04-17 01:11:00

2020-04-23 15:08:41

SpringBootMyCatJava

2024-09-26 08:03:37

2010-01-07 09:59:16

RESTMVC

2009-05-08 08:59:35

RESTORBSOA

2025-03-21 08:55:36

SpringOpenFeignAPI

2022-04-28 07:31:41

Springkafka數據量

2024-09-05 08:58:37

2022-12-19 08:00:00

SpringBootWeb開發

2023-11-10 08:17:01

分布式搜索引擎

2023-07-03 15:55:05

語法jpa狀態

2025-01-09 08:15:11

2023-08-31 08:34:07

Users對象序列化

2024-09-11 08:35:54

2023-08-29 08:00:38

2025-04-23 08:50:00

SpringBootCurator分布式鎖

2023-05-11 12:40:00

Spring控制器HTTP
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品一区二区三区在线视频 | 一区二区三区四区五区在线视频 | 国产精品福利一区二区三区 | 久久999 | 91在线精品秘密一区二区 | 欧美福利在线 | 新av在线| 中文字幕精品一区久久久久 | 久久久在线视频 | 国产在线资源 | 国产三级精品三级在线观看四季网 | 欧美九九 | 国产亚洲精品久久久久久豆腐 | 精品一区二区三区四区 | 久久久国产视频 | 国产精品久久影院 | 欧美一级电影免费观看 | 久久久xxx | 在线黄色网| 日韩在线播放第一页 | 伊人热久久 | 欧美视频三区 | 精品视频一区二区三区在线观看 | 一级做a爰片性色毛片16 | 黄色电影在线免费观看 | 欧美一卡二卡在线观看 | 国产一区不卡 | 日韩有码一区 | 雨宫琴音一区二区在线 | 国产乱码精品一区二区三区忘忧草 | 久久久久久久香蕉 | 懂色中文一区二区在线播放 | 成人一区二区视频 | 欧美一区视频在线 | 超碰日本 | 毛片一级网站 | 国产一区二区激情视频 | 久久久亚洲 | 三级成人在线 | 日本福利一区 | 国产欧美在线播放 |