cxf 相关知识整理

① 请求方式为GET

   @GET

    @Path(value = "/userAddressManage")

    @Produces( { MediaType.APPLICATION_JSON, "text/html; charset=UTF-8" })

    public BuyerAddressResponseModel userAddressManage( @QueryParam("buyerTel") String buyerTel,

              @QueryParam("detailAddress") String detailAddress);

 和POST请求方式对应的获取参数数据的方式是: @QueryParam

 

② 请求方式为POST

通过GET的方式来提交数据,参数的长度是都限制的,当数据的长度超过了限制,请求会失败。

这种情况下就不得不使用POST请求了。

 @POST

    @Path(value = "/addOrder")

    @Produces( { MediaType.APPLICATION_JSON, "text/html; charset=UTF-8" })

    public OrderResponseModel addOrder(

            @FormParam("orderInfo") String orderInfo,

            @FormParam("orderDetailsList") String orderDetailsList,

            @FormParam("addressInfo") String addressInfo);

 和POST请求方式对应的获取参数数据的方式是: @FormParam

 

③ CXF相关注解整理

1)@WebService 和 @WebMethod 是 WSDL 映射 Annatotion。描述 Web Service 的 WSDL 文档元素和 Java 源代码联系在一起。

2)@WebParam 用来获取请求参数

3)@WebResult用来定义返回值

4)@SOAPBinding 是一个绑定的 annotation 用来说明网络协议和格式。 

 

使用annotation 定义了webservice

import java.util.List;

import javax.jws.WebMethod;

import javax.jws.WebParam;

import javax.jws.WebResult;

import javax.jws.WebService;

import com.cxf.pojo.User;



@WebService(targetNamespace = "http://jdk.study.hermit.org/client")

public interface UserService {

    @WebMethod(operationName = "Insert")

    public void insert(
       @WebParam(name = "userId") String userid, @WebParam(name = "userName") String username, @WebParam(name = "userEmail") String useremail, @WebParam(name = "userAge") int userage); @WebMethod(operationName = "GetUserById") @WebResult(name = "result") public User getUserById(@WebParam(name = "userid") String userid); @WebMethod(operationName = "GetAllUsers") @WebResult(name = "result") public List getAllUsers(); }

 

实现类如下:

import  java.util.List; 

import  javax.jws.WebService; 



import  com.cxf.dao.UserDao; 

import  com.cxf.pojo.User; 

import  com.cxf.service.UserService; 



@WebService (endpointInterface= "com.cxf.service.UserService" ) 

publicclass UserServiceImpl  implements  UserService { 



  private UserDao  userDao ; 

  public List getAllUsers() { return userDao .findAllUser(); } 

  public User  getUserById(String userid) { return userDao .findUserById(userid);} 



  publicvoid insert(String userid, String username, String useremail,  int  userage) { 

    User user= new  User(); 

    user.setUserage(userage); 

    user.setUseremail(useremail); 

    user.setUserid(userid); 

    user.setUsername(username); 

    userDao .insert(user); 

    System. out .println( "insert successfully!" ); 

  } 



  public   void  setUserDao(UserDao userDao) { 

    this . userDao  = userDao; 

  } 

} 
注意:实现类中的@WebService ,其中的 endpointInterface 成员指定了该类实现的接口

下面介绍restful在springMVC下的注解

  
Annotation 注解在 javax.ws.rs.* 中定义,是 JAX-RS (JSR 311) 规范的一部分。
@Path       定义资源基 URI。由上下文根和主机名组成,资源标识符类似于 http://localhost:8080/RESTful/rest/hello 在类和方法上使用
@GET      这意味着以下方法可以响应 HTTP GET 方法
@Produces   以纯文本方式定义响应内容 MIME 类型
@Context    使用该注释注入上下文对象,比如 Request、Response、UriInfo、ServletContext
@FormParam  接收POST方式提交的参数
@QueryParam 接收GET方式提交的参数
@Consumes    声明该方法使用 HTML FORM
@Produces( { MediaType.APPLICATION_JSON, "text/html; charset=UTF-8" })

定义REST接口服务

package demo.ws.rest_cxf;

 

import java.util.List;

import java.util.Map;

import javax.ws.rs.Consumes;

import javax.ws.rs.DELETE;

import javax.ws.rs.FormParam;

import javax.ws.rs.GET;

import javax.ws.rs.POST;

import javax.ws.rs.PUT;

import javax.ws.rs.Path;

import javax.ws.rs.PathParam;

import javax.ws.rs.Produces;

import javax.ws.rs.core.MediaType;

 

public interface ProductService {

 

    @GET

    @Path("/products")

    @Produces(MediaType.APPLICATION_JSON)

    List<Product> retrieveAllProducts();

 

    @GET

    @Path("/product/{id}")

    @Produces(MediaType.APPLICATION_JSON)

    Product retrieveProductById(@PathParam("id") long id);

 

    @POST

    @Path("/products")

    @Consumes(MediaType.APPLICATION_FORM_URLENCODED)

    @Produces(MediaType.APPLICATION_JSON)

    List<Product> retrieveProductsByName(@FormParam("name") String name);

 

    @POST

    @Path("/product")

    @Consumes(MediaType.APPLICATION_JSON)

    @Produces(MediaType.APPLICATION_JSON)

    Product createProduct(Product product);

 

    @PUT

    @Path("/product/{id}")

    @Consumes(MediaType.APPLICATION_JSON)

    @Produces(MediaType.APPLICATION_JSON)

    Product updateProductById(@PathParam("id") long id, Map<String, Object> fieldMap);

 

    @DELETE

    @Path("/product/{id}")

    @Produces(MediaType.APPLICATION_JSON)

    Product deleteProductById(@PathParam("id") long id);

}

 

以上 ProductService 接口中提供了一系列的方法,在每个方法上都使用了 JAX-RS 提供的注解,主要包括以下三类:

  1. 请求方式注解,包括:@GET、@POST、@PUT、@DELETE
  2. 请求路径注解,包括:@Path ,其中包括一个路径参数
  3. 数据格式注解,包括:@Consumes(输入)、@Produces(输出),可使用 MediaType 常量
  4. 相关参数注解,包括:@PathParam(路径参数)、@FormParam(表单参数),此外还有 @QueryParam(请求参数)

针对 updateProductById 方法,简单解释一下:

该方法将被 PUT:/product/{id} 请求来调用,请求路径中的 id 参数将映射到 long id 参数上,请求体中的数据将自动转换为 JSON 格式并映射到 Map<String, Object> fieldMap 参数上,返回的 Product 类型的数据将自动转换为 JSON 格式并返回到客户端。

 

参考网址:

http://my.oschina.net/huangyong/blog/294324

http://www.cnblogs.com/hoojo/archive/2012/07/23/2605219.html

 

你可能感兴趣的:(CXF)