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

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

(0)

相关推荐

  • 基于Restful接口调用方法总结(超详细)

    由于在实际项目中碰到的restful服务,参数都以json为准.这里我获取的接口和传入的参数都是json字符串类型.发布restful服务可参照文章 Jersey实现Restful服务(实例讲解),以下接口调用基于此服务. 基于发布的Restful服务,下面总结几种常用的调用方法. (1)Jersey API package com.restful.client; import com.fasterxml.jackson.core.JsonProcessingException; import

  • Restful API中的错误处理方法

    简介 随着移动开发和前端开发的崛起,越来越多的 Web 后端应用都倾向于实现 Restful API. Restful API 是一个简单易用的前后端分离方案,它只需要对客户端请求进行处理,然后返回结果即可, 无需考虑页面渲染,一定程度上减轻了后端开发人员的负担. 然而,正是由于 Restful API 不需要考虑页面渲染,导致它不能在页面上展示错误信息. 那就意着当出现错误的时候,它只能通过返回一个错误的响应,来告诉用户和开发者相应的错误信息,提示他们接下来应该怎么办. 本文将讨论 Restf

  • Restful传递数组参数及注解大全

    RESTful 一种软件架构风格,设计风格而不是标准,只是提供了一组设计原则和约束条件.它主要用于客户端和服务器交互类的软件.基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制. 需要传递数组参数的情况,如果是一般的form表单,可以直接定义参数类型为List<String>即可(不能定义为数组类型,否则只能得到一个null). 示例代码如下: @POST @Path("/user" ) public Response createUser(@FormPara

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

    缘起 工作时使用java开发服务器后台,用Jersey写Restful接口,发现有一个Post方法始终获取不到参数,查了半天,发现时获取参数的注释不太对,将@formparam写成了@queryparam,发现了这个改过来就好了,顺便整理了一下不同参数的作用. 简述 获取URI的参数 获取Get请求的参数 获取Post类型的参数 添加参数默认值 获取Map参数 1.@PathParam 使用该注释获取参数时可以获取URI中制定规则的参数 例如: //该类的路径为/user @GET @Path(

  • Jmeter接口登录获取参数token报错问题解决方案

    Jmeter接口登录时获取到的参数token一直在变的问题,导致运行时总是报错 解决方法如下: 1.新建一个GET的HTTP请求 2.添加正则表达式提取器 记得name="_token" value="(.+?) 中间有一个空格,"_token"和value中间的空格(之前在这边耗费了很多时间) 3.新建一个POST的HTTP请求用于登录,_token值写为${token} 4.新建一个Debug Sampler用于查看获取到的token 值 5.运行,察

  • python+excel接口自动化获取token并作为请求参数进行传参操作

    1.登录接口登录后返回对应token封装: import json import requests from util.operation_json import OperationJson from base.runmethod import RunMethod class OperationHeader: def __init__(self, response): self.response = json.loads(response) def get_response_token(self

  • Java进阶之走进RESTful接口

    一.什么是API API (应用程序编程接口) 两种用法 1.类似jar的使用:A软件将功能打包成组件(功能块:比如java中的jar),让B软件导入直接使用 2.http请求方式:A项目(系统)提供一个映射方法路径,B项目(系统)发起http请求得到对应功能 (应用请求方式) 应用接口:很多情况下,需要把系统的部分功能(组件)作为服务暴露给外部的其他应用使用,所以就需要把系统中的服务作为API接口暴露出去,一般分为公共接口和私用接口(公司内部) 二.了解Web技术的发展阶段 静态内容阶段:We

  • PHP编写RESTful接口

    首先我们来认识下RESTful Restful是一种设计风格而不是标准,比如一个接口原本是这样的: http://www.test.com/user/view/id/1 表示获取id为1的用户信息,如果使用Restful风格,可以变成这样: http://www.test.com/user/1 可以很明显的看出这样做的好处: 1.更简洁的URL,对程序员友好 2.不暴露内部代码结构,更安全 那么,如何实现这个接口呢?首先,我们需要接收到/user/1部分. $path = $_SERVER['P

  • java调用Restful接口的三种方法

    目录 1,基本介绍 2,HttpURLConnection实现 3.HttpClient实现 4.Spring的RestTemplate 1,基本介绍 Restful接口的调用,前端一般使用ajax调用,后端可以使用的方法比较多, 本次介绍三种: 1.HttpURLConnection实现 2.HttpClient实现 3.Spring的RestTemplate 2,HttpURLConnection实现 @Controller public class RestfulAction { @Aut

  • SpringBoot接口接收json参数解析

    目录 SpringBoot接口接收json参数 前言 前提 一.GET 二.DELETE 三.POST/PUT/PATCH Springboot restFul 参数检验 概述 常用注解 简单应用举例 自定义校验 抛出BindException而非MethodArgumentNotValidException SpringBoot接口接收json参数 前言 通常来讲,HTTP 方法会映射为 CRUD 动作,但这并不是严格的限制,有时候 PUT 也可以用来创建新的资源,POST 也可以用来更新资源

  • spring常用注解开发一个RESTful接口示例

    目录 一.开发REST接口 1.第一步:定义资源(对象) 2.第二步:HTTP方法与Controller(动作) 二.统一规范接口响应的数据格式 一.开发REST接口 在本专栏之前的章节中已经给大家介绍了 Spring常用注解及http数据转换教程 Spring Boot提高开发效率必备工具lombok使用 Spring Boot开发RESTful接口与http协议状态表述 本节内容就是将之前学到的内容以代码的方式体现出来. 1. 第一步:定义资源(对象) @Data @Builder publ

  • Spring Boot开发RESTful接口与http协议状态表述

    目录 一.RESTful风格API的好处 二.RESTfulAPI的设计风格 2.1.RESTful是面向资源的(名词) 2.2.用HTTP方法体现对资源的操作(动词) 2.3.HTTP状态码 2.4.Get方法和查询参数不应该改变数据 2.5.使用复数名词 2.6.复杂资源关系的表达 2.7.高级用法:HATEOAS 2.8.资源过滤.排序.选择和分页的表述 2.9.版本化你的API 参考: 一.RESTful风格API的好处 API(Application Programming Inter

随机推荐