一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 使用CXF和Jersey框架來進行Java的WebService編程

使用CXF和Jersey框架來進行Java的WebService編程

2020-03-14 15:10cxshun JAVA教程

這篇文章主要介紹了使用CXF和Jersey框架來進行Java的WebService編程,Web service是一個平臺獨立的低耦合的自包含的基于可編程的web的應用程序,需要的朋友可以參考下

CXF
CXF是在xfire的基礎上實現的。
1)首先呢,還是包的問題,在http://cxf.apache.org/download.html這里可以下到最新版的CXF,當然,我用的是最新版的。接下來還是那句廢話,建WEB項目,放入JAR包。而JAR包我們就不選擇了,一堆全部放入。
我們會看到它包含了spring的JAR包,后面當我們需要把CXF作為WEB項目部署時,就需要用到spring的配置文件,這個后面再講。
還是接口類和實現類:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@WebService
public interface IReaderService {
  public Reader getReader(@WebParam(name="name") String name,@WebParam(name="password") String password);
  public List<Reader> getReaders();
}
@WebService(endpointInterface="com.cxf.servlet.IReaderService",serviceName="readerService")
public class ReaderService implements IReaderService{
  public Reader getReader(@WebParam(name="name") String name,@WebParam(name="password") String password) {
    return new Reader(name,password);
  }
   
  public List<Reader> getReaders(){
    List<Reader> readerList = new ArrayList<Reader>();
    readerList.add(new Reader("shun1","123"));
    readerList.add(new Reader("shun2","123"));
    return readerList;
  }
}

 這兩個類除了加入注解外,其他均和昨天講的webservice的一樣。這里就不多講了,對注解的解釋,大家可以看看JAVAEE的文檔。不過按意思應該很容易理解的。
接下來就是JAVABEAN,還是那個Reader類:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class Reader{
  private static final long serialVersionUID = 1L;
  private String name;
  private String password;
   
  public Reader(){}
  public Reader(String name,String password) {
    this.name = name;
    this.password = password;
  }
  //Get/Set方法省略
  public String toString(){
    return "Name:"+name+",Password:"+password;
  }
   
}

 上面的已經寫完了。
2)我們要用做WEB項目嗎?不急,先不用,CXF自帶了一個輕量的容器服務,相當于spring自己提供了IOC容器一樣。我們可以先用它來測試一下我們部署成功沒。
直接來一個測試類:

?
1
2
3
4
5
6
public static void main(String[] args) {
    System.out.println("Server is starting...");
    ReaderService readerService = new ReaderService();
    Endpoint.publish("http://localhost:8080/readerService",readerService);
    System.out.println("Server is started...");
  }

 簡單得不得了吧。直接publish地址,然后指定接口或類就OK了。我這里用的是類,但盡量用接口,畢竟面向接口編程才是真正的面對對象思想。
我們啟動看看結果:

使用CXF和Jersey框架來進行Java的WebService編程

 我們看到啟動已經完成,接著啟動瀏覽器看看是否成功了。
直接在瀏覽器輸入http://localhost:8080/readerService?wsdl,我們可以看到:

使用CXF和Jersey框架來進行Java的WebService編程

它生成了我們所需要的wsdl文件,說明我們部署成功了。
3)部署成功后,我們就是要調用啦,它的調用也相當簡單,跟xfire類似,取得接口,然后就可以跟本地類一樣調用方法了。

?
1
2
3
4
5
6
7
8
9
public static void main(String[] args) {
    JaxWsProxyFactoryBean factoryBean = new JaxWsProxyFactoryBean();
    factoryBean.setServiceClass(IReaderService.class);
    factoryBean.setAddress("http://localhost:8080/readerService");
     
    IReaderService readerService = (IReaderService)factoryBean.create();
    Reader reader = readerService.getReader("shun","123");
    System.out.println("Reader:"+reader);
  }

 這里很簡單,也是取得一個工廠類,然后直接設接口和地址再create就可以得取相應的接口了,這里跟xfire一樣,也是需要調用端先定義好接口原型,否則這些調用將無從說起。
我們運行得到結果:

使用CXF和Jersey框架來進行Java的WebService編程

沒問題,跟我們預想的結果一致。
 
4)但很多情況下,我們并不希望我們的webservice和我們的應用分開兩個服務器,而希望他們在同一個容器,tomcat或JBOSS或其他的,這樣我們就必須通過WEB來部署我們前面完成的webservice。
注意,我們這里需要用到spring定義文件。
首先看看web.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  id="WebApp_ID" version="3.0">
   
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>WEB-INF/beans.xml</param-value>
  </context-param>
   
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
   
  <servlet>
    <servlet-name>CXFServlet</servlet-name>
    <servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>CXFServlet</servlet-name>
    <url-pattern>/webservice/*</url-pattern>
  </servlet-mapping>
</web-app>

 這里很簡單,只是指定了spring的監聽器和相應的配置文件路徑,并且指定了CXF的攔截方式。
接下來看看beans.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:jaxws="http://cxf.apache.org/jaxws"
  xsi:schemaLocation="
    http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://cxf.apache.org/jaxws
    http://cxf.apache.org/schemas/jaxws.xsd">
  <import resource="classpath:META-INF/cxf/cxf.xml" />
  <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />
  <import resource="classpath:META-INF/cxf/cxf-servlet.xml" />
   
  <jaxws:endpoint id="readerServicce2"
    implementor="com.cxf.servlet.ReaderService" address="/readerService2" />
</beans>

 這里很簡單,只是通過jaxws:endpoint定義了一個webservice,implementor是webservice的處理類,而address是它的訪問路徑,跟我們前面寫的readerService類似。
這時我們可以把它部署到tomcat中,通過http://localhost:8080/CXFWebservice/webservice/readerService2?wsdl可以直接訪問。
 
有些朋友會問,為什么這次訪問的URL跟前面的不一樣呢。其實前面的訪問地址是我們自己定義的,而這里的webservice地址是我們在配置文件中配置好的,并且是通過web項目來部署的,這里就需要用項目名稱,而且我們在CXFServlet那里配置了url-pattern是webservice,所以最后的URL就跟上面一致了。
我們可以看到效果:

使用CXF和Jersey框架來進行Java的WebService編程

 這證明我們部署成功了。
 
可以再次用前面的測試類測試一下,注意,需要把address修改成我們發布后的URL。
CXF相比xfire又更簡潔了一些,雖然它增加了一些注解,但這些無傷大雅,它只是把以前的services.xml中的信息集中到類中,反而更方便維護,但這還是見仁見智的,有些人就喜歡配置文件,而有些人就不喜歡。另外CXF的調用方式更加簡潔,比起xfire它的代碼量更小了,是一個較大的進步。
 
有些朋友在搭建的過程中出現了一些問題,免去一個個回復了,這里放出代碼,有需要的朋友可以下載看看。
lib目錄下的所有包均沒有放入,把cxf的所有包放入即可。
注:所用IDE為idea,文件結構跟eclipse不通用,如果需要在eclipse下使用的,可以直接復制代碼和文件到eclipse新建的項目即可。

Jersey
我們來看看它的基本用法。
 直接來個項目看看。開始項目之前大家還是先自己去下載包:https://maven.java.net/content/repositories/releases/com/sun/jersey/要運行例子需要同時下載server和client。當然不想找那么多,可以直接下這個zip包,https://maven.java.net/service/local/artifact/maven/redirect?r=releases&g=com.sun.jersey&a=jersey-archive&v=1.10&e=zip
 1)直接來個JAVABEAN

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@XmlRootElement
public class Reader implements Serializable{
  private static final long serialVersionUID = 1L;
  private String name;
  private String password;
   
  public Reader(){}
  public Reader(String name,String password) {
    this.name = name;
    this.password = password;
  }
  //省略Get/Set方法
  public String toString(){
    return "Name:"+name+",Password:"+password;
  }
}

  這里用到了一個標簽,這里用到的表示它返回的時候的類型,即此Reader類可以用于XML返回。
 2)來個service類,這時已經不用像以前的CXF和xfire一樣要接口了,直接來個類就OK了。 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
@Path("/readerService/{name}/{password}")
public class ReaderService {
   
  @GET
  @Produces(MediaType.APPLICATION_JSON)
  public Reader getReader(@PathParam("name") String name,@PathParam("password") String password) {
    return new Reader(name,password);
  }
   
  public static void main(String[] args) throws IllegalArgumentException, IOException, URISyntaxException {
    HttpServer server = HttpServerFactory.create("http://localhost:8080/");
    server.start();
  }
}

  這時用到了幾個標簽,Path相信用過springMVC的朋友應該知道這種寫法,就是URL匹配,如果不清楚的,可以先去看看。Get標簽表示這個方法只能通過Get方法來進行訪問,而Produces表示生成的結果,它表示系統會把Reader對象封閉成JSON結果進行返回。
 如果不理解不要緊,等一下看結果就可以理解了。
 而這時有一個main方法,相信有很大疑問吧。這是jersey內部提供的一個輕量級的內部容器,它可以暫時供我們調試用,但真正使用肯定不能用這個。
 3)我們寫一個測試類

?
1
2
3
4
5
6
7
8
9
10
public class ReaderClient {
 
  public static void main(String[] args) {
    Client client = Client.create();
    WebResource resource = client.resource("http://localhost:8080/readerService/shun/123213");
    Reader reader = resource.get(Reader.class);
    System.out.println(reader);
  }
 
}

  很簡單的代碼,應該都看得懂的,一個client對象,請求webservice,返回一個resource,然后resource就直接調用相應的方法,當然這個方法是通過我們的URl來進行匹配的。
 
 這里我們先用它自帶的一個輕量級服務測試一下。直接運行ReaderService,它里面有包含一個main方法,運行后,我們再運行ReaderClient,我們可以看到結果為:

使用CXF和Jersey框架來進行Java的WebService編程

  結果正確。
 
 我們當然不想就這樣用自帶的輕量級服務來作為我我們的服務器,我們需要放到和我們的項目在同一個服務器,比如tomcat,jboss等。
 4)WEB項目當然就少不了web.xml。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  id="WebApp_ID" version="3.0">
  <servlet>
    <servlet-name>Jersey Web Application</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Jersey Web Application</servlet-name>
    <url-pattern>/rest/*</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

  這時指定了rest路徑下的所有都將被jersey進行攔截。
 我們部署到tomcat下啟動后再重新運行readerClient,注意先要修改resource的路徑:

?
1
WebResource resource = client.resource("http://localhost:8080/jerseyWebService/rest/readerService/shun/123213");

  我的項目名為jerseyWebService,請根據你的項目名進行修改。
 修改后,我們重新運行,結果如下:

使用CXF和Jersey框架來進行Java的WebService編程

和上面的結果一致,說明部署的效果是一樣的,也是正確的。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91成| 韩国三级年轻的小婊孑 | 福利视频一区二区三区 | 美女叽叽| 亚洲香蕉视频 | 青青成人在线 | 国产精品一级香蕉一区 | 欧美成人福利视频 | 精品国产精品国产偷麻豆 | 四虎在线永久免费视频网站 | bestialitysex杂交 bedfriend泰剧全集免费观看 | bbwfreehd女厕所ved | 99av导航| 国产精品九九热 | 精品亚洲永久免费精品 | 极品妖艳许清赵丽全文免费阅读 | chinese圣水黄金调教 | 天堂中文在线观看 | aaa一级最新毛片 | 男人插曲女人下面 | 亚洲欧美日韩国产一区二区精品 | jiuse在线| 精品免费视在线视频观看 | 国色天香 社区视频 | 亚洲成年www | 欧美人交性视频在线香蕉 | 2020国产精品视频 | 动漫美女强行被吸乳做羞羞事 | 四虎影视在线影院在线观看观看 | 高清黄色直接看 | 果冻传媒在线视频观看免费 | 亚洲成人国产 | wwwav在线 | 亚洲精品综合一区二区 | 日本黄a | 我在厨房摸岳的乳HD在线观看 | 美女把小内内脱个精光打屁屁 | 男人边吃奶边做好爽视频免费 | 五月色婷婷在线影院 | 婷婷sese| 成人精品网 |