一马平川1

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

REST接口目前有2种方式: 一种是遵循了jax-rs规范的,使用的是@Path,@PathParam等注解.一种是Spring自有的一套,使用的是@RestController,@GetMapping等注解.

如何开发jax-rs规范的REST接口呢?

在SpringBoot项目中,可以按如下步骤进行:

1. 引入依赖: spring-boot-starter-jersey

2. 添加配置: 

public class JerseyConfig extends ResourceConfig{

  public JerseyCongfig(){

    super.register(jax-rs规范的REST接口所在实现类.class);

  }

}
3. 具体使用:

  有2种方式,一种是简单的直接使用实现类作为接口所在类,一种是接口与实现类搭档的方式.

  3.1 直接以实现类作为接口所在类的方式与Spring的Controller类似,只不过改为使用jax-rs规范的@Path,@PathParam注解

  @Path("/user")

  @Produces("application/json")

  public class MyController{

    @Path("/getName/{name}")

    @GET

    public String getName(@PathParam("name")String name){

      return name;

    }

  }

  3.2 以接口与实现类搭档的方式

  接口:

  @Path("/user")

  @Produces("application/json")

  public interface IMyControllerService {

    @Path("/getName/{name}")

    @GET

    String getName(@PathParam("name")String name);

 

  }

  

  实现类:

  public class MyController implements IMyControllerService{

    public String getName(String name){

      return name;

    }

  }

4.注意点

  无论哪种使用方式,都要将实现类注册到ResourceConfig中,否则找不到.

  用一个对象不能接收多个path参数, 如果需要用,需要其他配置

  可以使用多个@PathParam接收多个path参数

 

posted on 2020-08-22 15:53  一马平川1  阅读(344)  评论(0编辑  收藏  举报