Jersey Restful接口如何获取参数的问题

 更新时间:2021年06月07日 14:52:27   作者:456又  
这篇文章主要介绍了Jersey Restful接口如何获取参数的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

缘起

工作时使用java开发服务器后台,用Jersey写Restful接口,发现有一个Post方法始终获取不到参数,查了半天,发现时获取参数的注释不太对,将@formparam写成了@queryparam,发现了这个改过来就好了,顺便整理了一下不同参数的作用。

简述

获取URI的参数

获取Get请求的参数

获取Post类型的参数

添加参数默认值

获取Map参数

1.@PathParam

使用该注释获取参数时可以获取URI中制定规则的参数

例如:

//该类的路径为/user
@GET
@Path("{username"})
@Produces(MediaType.APPLICATION_JSON)
public User getUser(@PathParam("username") String userName) {
 ...}

当浏览器请求

http://localhost:8080/user/jack

时,username的值就是jack。请注意,这里的username并不是说key的值就是username,value是jack,而是说/user/后面就跟着username,这里的username只是一个变量。

2.@QueryParam

该参数用于获取Get请求中的查询参数,他和上一个的区别是它是通过URI中的?符号来实现的。

比如:

@GET
@Path("/user")
@Produces("text/plain")
public User getUser(@QueryParam("name") String name, @QueryParam("age") int age) { 
...}

当url的请求是

http://localhost:8080/user?name=cesar&age=21

时,此时函数获取的参数就是name=cesar而age=21;

3.@FormPara

顾名思义,是从Post请求的表单中获取数据。

@POST
@Consumes("application/x-www-form-urlencoded")
publicvoid post(@FormParam("name") String name) { 
// Store the message
}

4.默认参数值DefaultValue

当你希望在函数获取参数时参数有一个默认值,那么就可以使用该注释,它的使用方法如下

@GET
@Path("/user")
@Produces("text/plain")
public User getUser(@QueryParam("name") String name, @DefaultValue("26") @QueryParam("age") int age) { 
...}

那么当请求age参数时如果age没有赋值,就会默认为26.

5.使用Map的参数@Context

在一个大型的server中,由于参数的多变,参数结构的调整很容易遇到问题,这时候就可以考虑使用@Context来进行注释了。例子如下:

@GET
public String get(@Context UriInfo ui) { 
 MultivaluedMap<String, String> queryParams = ui.getQueryParameters(); 
MultivaluedMap<String, String> pathParams = ui.getPathParameters();
}

从例子中我们可以看出,其实Context就是其他几个参数的集合而已,只要熟练掌握了这几种参数以及他们代表的意义,你就可以熟练的操作Jersey了!

Restful接口传入多参数的问题及解决方案

结论:

restful风格的接口不支持多个参数

注:本文指的是通过json序列化参数的情况

1. 前置

一个定义用来测试的MyParam类

public class MyParam {
    private String str;
    private Integer integer;
    // 省略 getter和setter……
    }

我在做测试的是用了Chrome的插件Advanced REST client,可以模拟浏览器发送各种请求,并自定义header和body。

测试的时候需要使用post方式,并在http请求header中加入

accept: application/json
content-type: application/json

然后在htpp请求的Body中,输入json格式的参数,如{"str":"bb","integer":3}。

以下是几种多参数接口的形式,以及输入参数,以及解析结果。

2. 第一种:两个String参数

@POST
@Path("demo")
public Result function(String param1, String param2);

传入的参数:

{"param1":"bb","param2":"cc"}

解析出来的参数:

param1: "{"param1":"bb","param2":"cc"}"

param2: ""

这样的风格,传输过来的参数,读取的时候会读取request body中的inputStream,然后两个参数循环解析,解析完第一个参数的时候,会关闭inputStream,第二个参数再去读取inputStream的时候,读取到的就是空。

这样的话,传入的参数全部会赋值给第一个String对象,而第二个String解析出来后就是空字符串。

3. 第二种:一个对象参数,一个String参数

对于 第一个参数是封装对象的情况,能解析出来第一个对象,而第二个参数也是拿不到。

这种情况下不会报错,只是解析第一个对象的时候没有问题,解析第二个String拿到的就是空字符串。

@POST
@Path("demo")
@Consumes({MediaType.JSON})
public Result function(MyParam myParam, String param);

传入的参数:

{"str":"helo","integer":2},"string":"test"

解析出来的参数:

param1: 能正确解析对象myParam,其两个属性能正确赋值。

param2: ""

4. 第三种:一个String参数,一个对象参数

如果把两个参数的位置交换,则会把传入的参数全部解析给第一个String,而解析第二个对象的时候,由于拿到的数据是空,所以会报错。如下:

@POST
@Path("demo")
public Result function(String param, MyParam myParam);

传入的参数:

{"str":"helo","integer":2},"string":"test"

解析出来的参数:

param1: "{"str":"helo","integer":2},"string":"test""

param2: 会报错

5.解决方法

要解决传入多个参数的问题,有几个思路:

1. 封装对象,把要传的多个参数封装成一个对象传入

2. 在访问路径中嵌入变量,使用@PathVariable注解,在请求路径中写 “/demo/{1}/{2}”,然后在请求路径中相应的位置替换为要穿的参数即可,这种也只适用于包装类,如String。

3. 改变请求的content type,使用content-type: application/x-www-form-urlencoded,这种使用form表单提交的形式,可以传入两个参数,要结合使用@FormParam注解

6.关于使用form形式传入参数

接口的定义形式要修改

@POST
@Path("demo")
@Consumes({MediaType.APPLICATION_FORM_URLENCODED})
public Result function(@FormParam(value="string1")String string1, @FormParam(value="string2")String string2);

请求时,header参数要修改

accept: application/json
content-type: application/x-www-form-urlencoded

请求Body中使用form形式

string1=wo&string2=kan

然后就可以正确解析到两个参数的值

解析出来的参数:

string1: wo

string2: kan

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Spring AOP的使用详解

    Spring AOP的使用详解

    这篇文章主要介绍了Spring AOP的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 基于SpringBoot的Docker部署实践

    基于SpringBoot的Docker部署实践

    在云计算和微服务架构日益普及的今天,Docker已成为一种主流的应用部署方式,本文将详细介绍如何将基于Spring Boot的项目部署到Docker容器中,需要的朋友可以参考下
    2023-07-07
  • 使用StringRedisTemplate操作Redis方法详解

    使用StringRedisTemplate操作Redis方法详解

    这篇文章主要为大家介绍了使用StringRedisTemplate操作Redis方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • MyBatis关联查询的实现

    MyBatis关联查询的实现

    MyBatis可以通过定义多个表的关联关系,实现多表查询,本文主要介绍了MyBatis关联查询的实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • IDEA不编译除了.java之外的文件的解决办法(推荐)

    IDEA不编译除了.java之外的文件的解决办法(推荐)

    这篇文章主要介绍了IDEA不编译除了.java之外的文件的解决办法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Java中mkdir()和mkdirs()的区别及说明

    Java中mkdir()和mkdirs()的区别及说明

    这篇文章主要介绍了Java中mkdir()和mkdirs()的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • struts2+spring+ibatis框架整合实现增删改查

    struts2+spring+ibatis框架整合实现增删改查

    这篇文章主要为大家详细介绍了struts2+spring+ibatis框架整合实现增删改查操作,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Java 中导入excel时使用 trim() 无法去除空格的问题解决方案

    Java 中导入excel时使用 trim() 无法去除空格的问题解决方案

    这篇文章主要介绍了Java中导入excel时使用trim()无法去除空格的解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • Quartz高可用定时任务的快速上手指南

    Quartz高可用定时任务的快速上手指南

    Quartz的分布式策略就是一种以数据库作为边界资源的并发策略,每个节点都遵守相同的操作规范,使得对数据库的操作可以串行执行,而不同名称的调度器又可以互不影响的并行运行,下面这篇文章主要介绍了Quartz高可用定时任务快速上手的相关资料,需要的朋友可以参考下
    2022-04-04
  • 使用SpringBoot项目导入openfeign版本的问题

    使用SpringBoot项目导入openfeign版本的问题

    这篇文章主要介绍了使用SpringBoot项目导入openfeign版本的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03

最新评论