REST接口目前有2种方式: 一种是遵循了jax-rs规范的,使用的是@Path,@PathParam等注解.一种是Spring自有的一套,使用的是@RestController,@GetMapping等注解.
如何开发jax-rs规范的REST接口呢?
在SpringBoot项目中,可以按如下步骤进行:
1. 引入依赖: spring-boot-starter-jersey
2. 添加配置:
1
2
3
4
5
|
public class JerseyConfig extends ResourceConfig{ public JerseyCongfig(){ super .register(jax-rs规范的REST接口所在实现类. class ); } } |
3. 具体使用:
有2种方式,一种是简单的直接使用实现类作为接口所在类,一种是接口与实现类搭档的方式.
3.1 直接以实现类作为接口所在类的方式与Spring的Controller类似,只不过改为使用jax-rs规范的@Path,@PathParam注解
1
2
3
4
5
6
7
8
9
|
@Path ( "/user" ) @Produces ( "application/json" ) public class MyController{ @Path ( "/getName/{name}" ) @GET public String getName( @PathParam ( "name" )String name){ return name; } } |
3.2 以接口与实现类搭档的方式
接口:
1
2
3
4
5
6
7
|
@Path ( "/user" ) @Produces ( "application/json" ) public interface IMyControllerService { @Path ( "/getName/{name}" ) @GET String getName( @PathParam ( "name" )String name); } |
实现类:
1
2
3
4
5
|
public class MyController implements IMyControllerService{ public String getName(String name){ return name; } } |
4.注意点
无论哪种使用方式,都要将实现类注册到ResourceConfig中,否则找不到.
用一个对象不能接收多个path参数, 如果需要用,需要其他配置
可以使用多个@PathParam接收多个path参数
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/wangxuejian/p/13545967.html