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