在发送@PathParam时,泽西项目Swagger-UI不会发送@HeaderParam

时间:2019-01-16 02:21:34

标签: java jersey swagger swagger-ui

使用以下Swagger Core的Java Jersey项目:

<dependency>
    <groupId>io.swagger.core.v3</groupId>
    <artifactId>swagger-jaxrs2</artifactId>
    <version>2.0.2</version>
</dependency>

文档链接转到“ openapi.json”。从here下载了Swagger-UI dist ver 3.20.5。 Java代码是这样的:

@Path("/auth")
public class TestConttroller {
    @GET
    @Path("/{id}")
    @Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML})
    public Response testGet(
                @DefaultValue("") @HeaderParam("Authorization") String a,
                @DefaultValue("") @PathParam("id") String id) 
    {
        return Response.ok().build();
    }

从邮递员发送请求时,一切正常。但是,当跟随Swagger-UI时,标头参数字符串“ a”是空字符串,而path-param字符串很好。 openapi.json中的部分在这里:

  "paths" : {
    "/auth/{id}" : {
      "get" : {
        "operationId" : "testGet",
        "parameters" : [ {
          "name" : "Authorization",
          "in" : "header",
          "schema" : {
            "type" : "string",
            "default" : ""
          }
        }, {
          "name" : "id",
          "in" : "path",
          "required" : true,
          "schema" : {
            "type" : "string",
            "default" : ""
          }
        } ],
        "responses" : {
          "default" : {
            "description" : "default response",
            "content" : {
              "application/json" : { },
              "application/xml" : { }
            }
          }
        }
      }
    }

与WireShark一起检查,发现根本没有请求标头。 Swagger-UI中应该出现问题吗? enter image description here

1 个答案:

答案 0 :(得分:0)

@HeaderParam(“ Authorization”)就像HTTP的关键字一样?当我使用“ Auth”之类的其他名称时,它会起作用。