久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

詳解JAVA中Jersey框架

小編這次要給大家分享的是詳解JAVA中Jersey框架,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

成都創(chuàng)新互聯(lián)是一家專(zhuān)業(yè)提供高陽(yáng)企業(yè)網(wǎng)站建設(shè),專(zhuān)注與網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、H5場(chǎng)景定制、小程序制作等業(yè)務(wù)。10年已為高陽(yáng)眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專(zhuān)業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

Java Jersey的詳情概述

Jersey是一個(gè)RESTFUL請(qǐng)求服務(wù)JAVA框架,與常規(guī)的JAVA編程使用的struts框架類(lèi)似,它主要用于處理業(yè)務(wù)邏輯層。

與springmvc 的區(qū)別:

1. jersey同樣提供DI,是由glassfish hk2實(shí)現(xiàn),也就是說(shuō),如果想單獨(dú)使用jersey一套,需要另外學(xué)習(xí)Bean容器;

2. MVC出發(fā)點(diǎn)即是WEB,但jersey出發(fā)點(diǎn)確實(shí)RESTFull,體現(xiàn)點(diǎn)在與接口的設(shè)計(jì)方面,
如MVC返回復(fù)雜結(jié)構(gòu)需要使用ModelAndView,而jersey僅僅需要返回一個(gè)流或者文件句柄;

3. jersey提供一種子資源的概念,這也是RESTFull中提倡所有url都是資源;

4. jersey直接提供application.wadl資源url說(shuō)明;

5. MVC提供Session等狀態(tài)管理,jersey沒(méi)有,這個(gè)源自RESTFull設(shè)計(jì)無(wú)狀態(tài)化;

6. Response方法支持更好返回結(jié)果,方便的返回Status,包括200,303,401,403;

7. 提供超級(jí)特別方便的方式訪問(wèn)RESTFull;

jersey

1.X的版本是sun公司提供的獨(dú)立的jar包,在2.X版本中,已經(jīng)將jersey融合到JavaSE中,在javax.ws.rs.*包中。

與Struts類(lèi)似,它同樣可以和hibernate,spring框架整合。

由于Struts2+hibernate+spring整合在市場(chǎng)的占有率太高,所以很少一部分人去關(guān)注Jersey。

所以網(wǎng)上有關(guān)于Jersey的介紹很少。但是它確實(shí)是一個(gè)非常不錯(cuò)的框架。對(duì)于請(qǐng)求式服務(wù),對(duì)于GET,DELETE請(qǐng)求,你甚至只需要給出一個(gè)URI即可完成操作。

舉個(gè)簡(jiǎn)單的例子:如果你想獲得服務(wù)器數(shù)據(jù)庫(kù)中的所有數(shù)據(jù);

那么你可以在瀏覽器或者利用Ajax的GET方法,將路徑設(shè)置好;

例如:localhost:8080/Student(項(xiàng)目名稱(chēng))/studentinfo(項(xiàng)目服務(wù)總體前綴)/student(處理student對(duì)象的簽注)/getStudentInfo(最后前綴)。

你可以選擇GET獲取的數(shù)據(jù)的返回類(lèi)型:JSON,XML,TEXT_HTML(String)..獲取之后,你可以通過(guò)JS將這些數(shù)據(jù)塞到html或者jsp頁(yè)面上。

Jersey是JAX-RS(JSR311)開(kāi)源參考實(shí)現(xiàn)用于構(gòu)建 RESTful Web service,它包含三個(gè)部分:

核心服務(wù)器(Core Server) :通過(guò)提供JSR 311中標(biāo)準(zhǔn)化的注釋和API標(biāo)準(zhǔn)化,可以用直觀的方式開(kāi)發(fā)RESTful Web服務(wù)。

核心客戶(hù)端(Core Client) :Jersey客戶(hù)端API能夠幫助開(kāi)發(fā)者與RESTful服務(wù)輕松通信;

集成(Integration) :Jersey還提供可以輕松繼承Spring、Guice、Apache Abdera的庫(kù)。

在本次開(kāi)發(fā)中使用Jersey2.0,并且僅使用了核心服務(wù)器。

設(shè)置Jersey環(huán)境

Maven

<!--jersey-->
<dependency>
 <groupId>org.glassfish.jersey.containers</groupId>
 <artifactId>jersey-container-servlet-core</artifactId>
 <version>2.0</version>
</dependency>

<!--JAXB API-->
<dependency>
 <groupId>javax.xml.ws</groupId>
 <artifactId>jaxws-api</artifactId>
 <version>2.1</version>
</dependency>

<!-- Json支持 -->
<dependency>
 <groupId>org.codehaus.jackson</groupId>
 <artifactId>jackson-core-asl</artifactId>
 <version>1.9.12</version>
</dependency>
<dependency>
 <groupId>org.codehaus.jackson</groupId>
 <artifactId>jackson-mapper-asl</artifactId>
 <version>1.9.12</version>
</dependency>
<dependency>
 <groupId>org.codehaus.jackson</groupId>
 <artifactId>jackson-jaxrs</artifactId>
 <version>1.9.12</version>
</dependency>

引入Jar文件方式

從Jersey開(kāi)發(fā)包中將以下庫(kù)復(fù)制的WEB-INF下的庫(kù)目錄:

1  服務(wù)器:jersey-server.jar 、jersey-container-servlet-core.jar、jersey-container-servlet.jar、javax.ws.rs-api-2.0.jar

2  客戶(hù)端:jersey-client.jar

3  common:jersey-common.jar

4  json支持:在Jersey2.0中需要使用 Jackson1.9 才能支持json。

Hello World

以下將展示一個(gè)Hello World

第一步: 編寫(xiě)一個(gè)名為HelloResource的資源,它接受Http Get請(qǐng)求并響應(yīng)“Hello Jersey”

@Path("/hello")
public class HelloResource {
 @GET
 @Produces(MediaType.TEXT_PLAIN)
 public String sayHello() {
  return "Hello Jersey";
 }
}

第二步: 編寫(xiě)JAX-RS application

public class APIApplication extends ResourceConfig {
  public APIApplication() {
 //加載Resource
 register(HelloResource.class);

 //注冊(cè)數(shù)據(jù)轉(zhuǎn)換器
 register(JacksonJsonProvider.class);

 // Logging.
 register(LoggingFilter.class);
  }
}

第三步: 在web.xml文件中定義servelt調(diào)度程序,目的是將所有REST請(qǐng)求發(fā)送到Jersey容器。除了聲明Jersey Servlet外,還需定義一個(gè)初始化參數(shù),指定JAX-RS application。

<!--用于定義 RESTful Web Service 接口-->
<servlet>
 <servlet-name>JerseyServlet</servlet-name>
 <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
 <init-param>
  <param-name>javax.ws.rs.Application</param-name>
  <param-value>cn.com.mink.resource.APIApplication</param-value>
 </init-param>

 <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
 <servlet-name>JerseyServlet</servlet-name>
 <url-pattern>/services/*</url-pattern>
</servlet-mapping>

在命令終端中輸入以下命令,將會(huì)看到“Hello Jersey”。

curl http://host:port/services/hello

或者在瀏覽器中輸入以下URL,將會(huì)看到“Hello Jersey”

http://host:port/services/hello

使用

資源

Root Resource And Sub-Resource

資源是組成RESTful服務(wù)的關(guān)鍵部分,可以使用HTTP方法(如:GET、POST、PUT和DELETE)操作資源。在JAX-RX中,資源通過(guò)POJO實(shí)現(xiàn),使用 @Path 注釋組成其標(biāo)識(shí)符。資源可以有子資源,父資源是資源集合,子資源是成員資源。

在以下樣例代碼中,

Resources是"/services" URI組成是集合資源,UserResource是“/services/user” URI組成的成員資源;

@Path("/services")
public class Resources {

 @Path("/user")
 public UserResource getUserResource() {
  ...
 }

 @Path("/book")
 public BookResource getBookResource() {
  ...
 }
}

UserResource是“/user” URI組成的集合資源,getUser是“/user/{username}” URI組成的資源方法

@Path("/user")
public class UserResource {
 @GET
 @Path("{username"})
 @Produces("application/json")
 public User getUser(@PathParam("username") String userName) {
  ...
 }
}

HTTP Methods

HTTP方法映射到資源的CRUD(創(chuàng)建、讀取、更新和刪除)操作,基本模式如下:

HTTP GET :讀取/列出/檢索單個(gè)或資源集合。

HTTP POST :新建資源。

HTTP PUT :更新現(xiàn)有資源或資源集合。

HTTP DELETE :刪除資源或資源集合。

@Produces

@Produces 注釋用來(lái)指定將要返回給client端的數(shù)據(jù)標(biāo)識(shí)類(lèi)型(MIME)。@Produces 可以作為class注釋?zhuān)部梢宰鳛榉椒ㄗ⑨專(zhuān)椒ǖ?@Produces 注釋將會(huì)覆蓋class的注釋。

1  指定一個(gè)MIME類(lèi)型

@Produces("application/json")

2  指定多個(gè)MIME類(lèi)型

@Produces({"application/json","application/xml"})

@Consumes

@Consumes 與 @Produces 相反,用來(lái)指定可以接受client發(fā)送過(guò)來(lái)的MIME類(lèi)型,同樣可以用于class或者method,也可以指定多個(gè)MIME類(lèi)型,一般用于 @PUT ,@POST 。

參數(shù)(Parameter Annotations)

Parameter Annotations用于獲取client發(fā)送的數(shù)據(jù)。本文只介紹常用的注解,更多詳見(jiàn) Jersey用戶(hù)手冊(cè)

@PathParam

使用 @PathParam 可以獲取URI中指定規(guī)則的參數(shù),比如:

@GET
@Path("{username"})
@Produces(MediaType.APPLICATION_JSON)
public User getUser(@PathParam("username") String userName) {
  ...
}

當(dāng)瀏覽器請(qǐng)求 http://localhost/user/jack 時(shí),userName值為jack。

@QueryParam

@QueryParam 用于獲取GET請(qǐng)求中的查詢(xún)參數(shù),如:

@GET
@Path("/user")
@Produces("text/plain")
public User getUser(@QueryParam("name") String name,
          @QueryParam("age") int age) {
  ...
}

當(dāng)瀏覽器請(qǐng)求 http://host:port/user&#63;name=rose&age=25 時(shí),name值為rose,age值為25。如果需要為參數(shù)設(shè)置默認(rèn)值,可以使用 @DefaultValue ,如:

@GET
@Path("/user")
@Produces("text/plain")
public User getUser(@QueryParam("name") String name,
          @DefaultValue("26") @QueryParam("age") int age) {
  ...
}

當(dāng)瀏覽器請(qǐng)求 http://host:port/user&#63;name=rose 時(shí),name值為rose,age值為26。

@FormParam

@FormParam ,顧名思義,從POST請(qǐng)求的表單參數(shù)中獲取數(shù)據(jù)。如:

@POST
@Consumes("application/x-www-form-urlencoded")
public void post(@FormParam("name") String name) {
  // Store the message
}

@BeanParam

當(dāng)請(qǐng)求參數(shù)很多時(shí),比如客戶(hù)端提交一個(gè)修改用戶(hù)的PUT請(qǐng)求,請(qǐng)求中包含很多項(xiàng)用戶(hù)信息。這時(shí)可以用 @BeanParam 。

@POST
@Consumes("application/x-www-form-urlencoded")
public void update(@BeanParam User user) {
  // Store the user data
}

User Bean定義如下:

@XmlRootElement(name = "user")
public class User {
 @PathParam("userName)
 private String userName;

 @FormParam("name")
 private String name;

 @FormParam("telephone")
 private String telephone;

 @FormParam("email")
 private String email;

 public String getUserName() {
  return userName;
 }

 public void setUserName(String userName) {
  this.userName = userName;
 }
 ...
}

使用Map

在一個(gè)大型的server中,因?yàn)閰?shù)的多變,參數(shù)結(jié)構(gòu)的調(diào)整都會(huì)因?yàn)橐陨蠋追N方式而遇到問(wèn)題,這時(shí)可以考慮使用 @Context 注釋?zhuān)@取UriInfo實(shí)例,如下:

@GET
public String get(@Context UriInfo ui) {
  MultivaluedMap<String, String> queryParams = ui.getQueryParameters();
  MultivaluedMap<String, String> pathParams = ui.getPathParameters();
}

同樣還可以通過(guò) @Context 注釋獲取 ServletConfig 、 ServletContext 、HttpServletRequest 、 HttpServletResponse 和 HttpHeaders 等,如下:

@Path("/")
public class Resource {

 @Context
 HttpServletRequest req;

 @Context
 ServletConfig servletConfig;

 @Context
 ServletContext servletContext;

 @GET
 public String get(@Context HttpHeaders hh) {
  MultivaluedMap<String, String> headerParams = hh.getRequestHeaders();
  Map<String, Cookie> pathParams = hh.getCookies();
 }
}

Jersey返回Json和Xml

JAX-RS支持使用JAXB(Java API for XML Binding)將JavaBean綁定到XML或JSON,反之亦然。JavaBean必須使用 @XmlRootElement 標(biāo)注,沒(méi)有@XmlElement 注釋的字段將包含一個(gè)名稱(chēng)與之相同的XML元素,如下:

@XmlRootElement
public class OptionResult {
 @XmlElement(name = "code")
 private String result;

 private String errorMsg;

 public String getResult() {
  return result;
 }

 public void setResult(String result) {
  this.result = result;
 }

 public String getErrorMsg() {
  return errorMsg;
 }

 public void setErrorMsg(String errorMsg) {
  this.errorMsg = errorMsg;
 }
}

然后在REST服務(wù)中使用:

@Path("/user")
public class UserResource {
 @POST
 @Produces("application/json")
 public OptionResult create(@BeanParam User user) {
  ...
 }
}

最后,要注冊(cè)數(shù)據(jù)轉(zhuǎn)換器,該轉(zhuǎn)換器會(huì)自動(dòng)將JavaBean轉(zhuǎn)換為json數(shù)據(jù):

public class APIApplication extends ResourceConfig {
  public APIApplication() {
 //加載Model
 register(OptionResult.class);

 //加載與OptionResult同一個(gè)packge的Model
 //packages(OptionResult.class.getPackage().getName());

 //加載Resource
 register(UserResource.class);

 //注冊(cè)數(shù)據(jù)轉(zhuǎn)換器
 register(JacksonJsonProvider.class);

 // Logging.
 register(LoggingFilter.class);
  }
}

說(shuō)明 :返回XML數(shù)據(jù)的原理相同,僅僅是數(shù)據(jù)轉(zhuǎn)換器不同,只需要在APIApplication中同時(shí)注冊(cè)XML數(shù)據(jù)轉(zhuǎn)換器即可,詳見(jiàn) Jersey用戶(hù)手冊(cè)

問(wèn)題總結(jié)

Ajax請(qǐng)求(POST、PUT和DELETE)無(wú)法將數(shù)據(jù)提交到Jersey容器

問(wèn)題闡述

在短信平臺(tái)的開(kāi)發(fā)中,數(shù)據(jù)的CRUD全部使用Ajax技術(shù)完成,因此必須使用POST、PUT和DELETE請(qǐng)求。此三種請(qǐng)求的content-type均為“application/x-www-form-urlencoded”,使用UTF-8編碼會(huì)變成“application/x-www-form-urlencoded; UTF-8”。在使用Firefox的tamperdata擴(kuò)展調(diào)試程序的過(guò)程中發(fā)現(xiàn),當(dāng)content-type為“application/x-www-form-urlencoded”時(shí),Jersey容器能夠通過(guò) @FormParam 注解獲取到提交的數(shù)據(jù),而content-type為“application/x-www-form-urlencoded; UTF-8”時(shí)便獲取不到。

解決方案

最終我使用Java Filter和Jersey RequestFilter解決了問(wèn)題。首先在Java Filter中使用UTF8將Request中的數(shù)據(jù)編碼,然后在Jersey RequestFilter中將request對(duì)象中的content-type修改為“application/x-www-form-urlencoded”。如:

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
 HttpServletRequest req = (HttpServletRequest)request;
 req.setCharacterEncoding("UTF-8");
}

public class RequestFilter implements ContainerRequestFilter {
 @Override
 public void filter(ContainerRequestContext context) throws IOException {
  String headerString = context.getHeaderString("content-type");
  if (headerString != null) {
   //如果content-type以"application/x-www-form-urlencoded"開(kāi)頭,則處理
    if (headerString.startsWith(MediaType.APPLICATION_FORM_URLENCODED))
    context.getHeaders().putSingle("content-type", MediaType.APPLICATION_FORM_URLENCODED);
  }
 }
}

最后在web.xml中注冊(cè)Java Filter(要注冊(cè)在Jersey容器之前),在APIApplication中注冊(cè)Jersey RequestFilter,如下:

public class APIApplication extends ResourceConfig {
  public APIApplication() {
    register(RequestFilter.class);
  }
}

看完這篇關(guān)于詳解JAVA中Jersey框架的文章,如果覺(jué)得文章內(nèi)容寫(xiě)得不錯(cuò)的話,可以把它分享出去給更多人看到。

網(wǎng)頁(yè)標(biāo)題:詳解JAVA中Jersey框架
路徑分享:http://sd-ha.com/article36/ghscsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、定制網(wǎng)站、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)網(wǎng)站制作、虛擬主機(jī)、外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化