Spring整合CXF webservice restful實(shí)例詳解
webservice restful接口跟soap協(xié)議的接口實(shí)現(xiàn)大同小異,只是在提供服務(wù)的類/接口的注解上存在差異,具體看下面的代碼,然后自己對比下就可以了。
用到的基礎(chǔ)類
User.java
@XmlRootElement(name="User")
public class User {
private String userName;
private String sex;
private int age;
public User(String userName, String sex, int age) {
super();
this.userName = userName;
this.sex = sex;
this.age = age;
}
public User() {
super();
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public static void main(String[] args) throws IOException {
System.setProperty("http.proxySet", "true");
System.setProperty("http.proxyHost", "192.168.1.20");
System.setProperty("http.proxyPort", "8080");
URL url = new URL("http://www.baidu.com");
URLConnection con =url.openConnection();
System.out.println(con);
}
}
接下來是服務(wù)提供類,PhopuRestfulService.java
@Path("/phopuService")
public class PhopuRestfulService {
Logger logger = Logger.getLogger(PhopuRestfulServiceImpl.class);
@GET
@Produces(MediaType.APPLICATION_JSON) //指定返回?cái)?shù)據(jù)的類型 json字符串
//@Consumes(MediaType.TEXT_PLAIN) //指定請求數(shù)據(jù)的類型 文本字符串
@Path("/getUser/{userId}")
public User getUser(@PathParam("userId")String userId) {
this.logger.info("Call getUser() method...."+userId);
User user = new User();
user.setUserName("中文");
user.setAge(26);
user.setSex("m");
return user;
}
@POST
@Produces(MediaType.APPLICATION_JSON) //指定返回?cái)?shù)據(jù)的類型 json字符串
//@Consumes(MediaType.TEXT_PLAIN) //指定請求數(shù)據(jù)的類型 文本字符串
@Path("/getUserPost")
public User getUserPost(String userId) {
this.logger.info("Call getUserPost() method...."+userId);
User user = new User();
user.setUserName("中文");
user.setAge(26);
user.setSex("m");
return user;
}
}
web.xml配置,跟soap協(xié)議的接口一樣
<!-- CXF webservice 配置 -->
<servlet>
<servlet-name>cxf-phopu</servlet-name>
<servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>cxf-phopu</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
Spring整合配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jaxws="http://cxf.apache.org/jaxws"
xmlns:jaxrs="http://cxf.apache.org/jaxrs"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd
http://cxf.apache.org/jaxrs http://cxf.apache.org/schemas/jaxrs.xsd">
<import resource="classpath:/META-INF/cxf/cxf.xml" />
<import resource="classpath:/META-INF/cxf/cxf-servlet.xml" />
<import resource="classpath:/META-INF/cxf/cxf-extension-soap.xml" />
<!-- 配置restful json 解析器 , 用CXF自帶的JSONProvider需要注意以下幾點(diǎn)
-1、dropRootElement 默認(rèn)為false,則Json格式會將類名作為第一個節(jié)點(diǎn),如{Customer:{"id":123,"name":"John"}},如果配置為true,則Json格式為{"id":123,"name":"John"}。
-2、dropCollectionWrapperElement屬性默認(rèn)為false,則當(dāng)遇到Collection時,Json會在集合中將容器中類名作為一個節(jié)點(diǎn),比如{"Customer":{{"id":123,"name":"John"}}},而設(shè)置為false,則JSon格式為{{"id":123,"name":"John"}}
-3、serializeAsArray屬性默認(rèn)為false,則當(dāng)遇到Collecion時,格式為{{"id":123,"name":"John"}},如果設(shè)置為true,則格式為[{"id":123,"name":"john"}],而Gson等解析為后者
<bean id="jsonProviders" class="org.apache.cxf.jaxrs.provider.json.JSONProvider">
<property name="dropRootElement" value="true" />
<property name="dropCollectionWrapperElement" value="true" />
<property name="serializeAsArray" value="true" />
</bean>
-->
<!-- 服務(wù)類 -->
<bean id="phopuService" class="com.phopu.service.PhopuRestfulService" />
<jaxrs:server id="service" address="/">
<jaxrs:inInterceptors>
<bean class="org.apache.cxf.interceptor.LoggingInInterceptor" />
</jaxrs:inInterceptors>
<!--serviceBeans:暴露的WebService服務(wù)類-->
<jaxrs:serviceBeans>
<ref bean="phopuService" />
</jaxrs:serviceBeans>
<!--支持的協(xié)議-->
<jaxrs:extensionMappings>
<entry key="json" value="application/json"/>
<entry key="xml" value="application/xml" />
<entry key="text" value="text/plain" />
</jaxrs:extensionMappings>
<!--對象轉(zhuǎn)換-->
<jaxrs:providers>
<!-- <ref bean="jsonProviders" /> 這個地方直接用CXF的對象轉(zhuǎn)換器會存在問題,當(dāng)接口發(fā)布,第一次訪問沒問題,但是在訪問服務(wù)就會報(bào)錯,等后續(xù)在研究下 -->
<bean class="org.codehaus.jackson.jaxrs.JacksonJaxbJsonProvider" />
</jaxrs:providers>
</jaxrs:server>
</beans>
客戶端調(diào)用示例:
對于get方式的服務(wù),直接在瀏覽器中輸入http://localhost:8080/phopu/services/phopuService/getUser/101010500 就可以直接看到返回的json字符串
{"userName":"中文","sex":"m","age":26}
客戶端調(diào)用代碼如下:
public static void getWeatherPostTest() throws Exception{
String url = "http://localhost:8080/phopu/services/phopuService/getUserPost";
HttpClient httpClient = HttpClients.createSystem();
//HttpGet httpGet = new HttpGet(url); //接口get請求,post not allowed
HttpPost httpPost = new HttpPost(url);
httpPost.addHeader(CONTENT_TYPE_NAME, "text/plain");
StringEntity se = new StringEntity("101010500");
se.setContentType("text/plain");
httpPost.setEntity(se);
HttpResponse response = httpClient.execute(httpPost);
int status = response.getStatusLine().getStatusCode();
log.info("[接口返回狀態(tài)嗎] : " + status);
String weatherInfo = ClientUtil.getReturnStr(response);
log.info("[接口返回信息] : " + weatherInfo);
}
客戶端調(diào)用返回信息如下:

ClientUtil類是我自己封裝的一個讀取response返回信息的類,encoding是UTF-8
public static String getReturnStr(HttpResponse response) throws Exception {
String result = null;
BufferedInputStream buffer = new BufferedInputStream(response.getEntity().getContent());
byte[] bytes = new byte[1024];
int line = 0;
StringBuilder builder = new StringBuilder();
while ((line = buffer.read(bytes)) != -1) {
builder.append(new String(bytes, 0, line, HTTP_SERVER_ENCODING));
}
result = builder.toString();
return result;
}
到這里,就介紹完了,大家手動去操作一下吧,有問題大家一塊交流。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring boot實(shí)現(xiàn)應(yīng)用打包部署的示例
本篇文章主要介紹了Spring boot實(shí)現(xiàn)應(yīng)用打包部署的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
最優(yōu)雅地整合 Spring & Spring MVC & MyBatis 搭建 Java 企業(yè)級應(yīng)用(附源碼)
這篇文章主要介紹了最優(yōu)雅地整合 Spring & Spring MVC & MyBatis 搭建 Java 企業(yè)級應(yīng)用(附源碼),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
Java報(bào)錯org.hibernate.TypeMismatchException的解決方法
在Java開發(fā)領(lǐng)域,尤其是涉及到數(shù)據(jù)持久化的項(xiàng)目中,Hibernate是一款廣泛使用的強(qiáng)大工具,然而,可能會在使用過程中遭遇各種報(bào)錯,其中org.hibernate.TypeMismatchException就是一個讓人頭疼的問題,下面我們一起深入剖析這個報(bào)錯信息2024-11-11
java如何將可運(yùn)行jar打包成exe可執(zhí)行文件
Java程序完成以后,對于Windows操作系統(tǒng)習(xí)慣總是想雙擊某個exe文件就可以直接運(yùn)行程序,這篇文章主要給大家介紹了關(guān)于java如何將可運(yùn)行jar打包成exe可執(zhí)行文件的相關(guān)資料,需要的朋友可以參考下2023-11-11

