diff --git a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamReqServiceImpl.java b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamReqServiceImpl.java index b8393be1e6..c8628adedb 100644 --- a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamReqServiceImpl.java +++ b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamReqServiceImpl.java @@ -21,7 +21,10 @@ import org.apache.dubbo.rest.demo.pojo.Person; import org.apache.dubbo.rest.demo.pojo.User; +import javax.ws.rs.core.Cookie; +import javax.ws.rs.core.HttpHeaders; import javax.ws.rs.core.MultivaluedMap; +import javax.ws.rs.core.UriInfo; import java.util.List; import java.util.Map; import java.util.Set; @@ -63,9 +66,30 @@ public List testMapForm(MultivaluedMap params) { return params.values().stream().flatMap(List::stream).toList(); } + @Override + public String testHeader(HttpHeaders headers) { + return headers.getHeaderString("name"); + } + + @Override + public String testUriInfo(UriInfo uriInfo) { + return uriInfo.getPath(); + } + + @Override + public String testForm(Person person) { + return person.getName(); + } + + @Override public Person testXml(Person person) { return person; } + @Override + public String testCookie(Cookie cookie) { + return cookie.getValue(); + } + } diff --git a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamRequestService.java b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamRequestService.java index a154f43015..80f331586c 100644 --- a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamRequestService.java +++ b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/complex/ComplexParamRequestService.java @@ -28,8 +28,12 @@ import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.Cookie; +import javax.ws.rs.core.HttpHeaders; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MultivaluedMap; +import javax.ws.rs.core.UriInfo; import java.util.List; import java.util.Map; import java.util.Set; @@ -64,15 +68,34 @@ public interface ComplexParamRequestService { @Produces(MediaType.TEXT_PLAIN) String testMapHeader(@HeaderParam("headers") String headerMap); + + @POST + @Path("/xml") + @Consumes(MediaType.TEXT_XML) + @Produces(MediaType.APPLICATION_XML) + Person testXml(Person person); + + + @GET + @Path("/cookie") + @Produces(MediaType.TEXT_PLAIN) + String testCookie(@Context Cookie cookie); @POST @Path("/testMapForm") @Produces({MediaType.APPLICATION_JSON}) @Consumes({MediaType.APPLICATION_FORM_URLENCODED}) List testMapForm(MultivaluedMap params); + @GET + @Path("/httpHeader") + String testHeader(@Context HttpHeaders headers); + + @GET + @Path("/uri") + @Produces(MediaType.TEXT_PLAIN) + String testUriInfo(@Context UriInfo uriInfo); @POST - @Path("/xml") - @Consumes(MediaType.TEXT_XML) - @Produces(MediaType.APPLICATION_XML) - Person testXml(Person person); + @Path("/annoForm") + @Produces(MediaType.TEXT_PLAIN) + String testForm(@org.jboss.resteasy.annotations.Form Person person); } diff --git a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/routine/BasicParamRequestService.java b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/routine/BasicParamRequestService.java index cc48eb107f..c3fb4ab5ba 100644 --- a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/routine/BasicParamRequestService.java +++ b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/main/java/org/apache/dubbo/rest/demo/routine/BasicParamRequestService.java @@ -23,7 +23,7 @@ import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.core.MediaType; - +@Path("/") public interface BasicParamRequestService { @GET @Path("/primitive") diff --git a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/test/java/org/apache/dubbo/rest/demo/test/ComplexParamRequestIT.java b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/test/java/org/apache/dubbo/rest/demo/test/ComplexParamRequestIT.java index c77cd12685..e800f69643 100644 --- a/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/test/java/org/apache/dubbo/rest/demo/test/ComplexParamRequestIT.java +++ b/2-advanced/dubbo-samples-triple-rest/dubbo-samples-triple-rest-jaxrs/src/test/java/org/apache/dubbo/rest/demo/test/ComplexParamRequestIT.java @@ -123,7 +123,6 @@ public void testSet() throws Exception { @Test public void testArray() throws Exception { - User[] array = {new User(1L,"1",1),new User(2L,"2",2)}; ResponseEntity response = RestClient.create().post() .uri("http://" + providerAddress +":50052/complex/array") @@ -153,7 +152,6 @@ public void testStringMap() throws Exception { @Test public void testHeader() throws Exception { - ResponseEntity response = RestClient.create().get() .uri("http://" + providerAddress +":50052/complex/testMapHeader") .header("Content-type", "application/json") @@ -194,7 +192,6 @@ public void testMapForm() throws Exception { @Test public void testXml() throws Exception { - // TODO xml String str = "1"; Person person = new Person("1"); @@ -220,4 +217,49 @@ public void testXml() throws Exception { Assert.assertEquals(person,result); } + @Test + public void testCookie(){ + ResponseEntity response = RestClient.create().get() + .uri("http://" + providerAddress + ":50052/complex/cookie") + .header("Content-type", "application/json") + .header( "cookie","cookie=1") + .retrieve() + .toEntity(String.class); + Assert.assertEquals("1",response.getBody()); + } + + @Test + public void testHttpHeader(){ + ResponseEntity response = RestClient.create().get() + .uri("http://" + providerAddress + ":50052/complex/httpHeader") + .header( "Content-type","text/plain") + .header( "name","world") + .retrieve() + .toEntity(String.class); + Assert.assertEquals("world", response.getBody()); + } + + @Test + public void testUri(){ + ResponseEntity response = RestClient.create().get() + .uri("http://" + providerAddress + ":50052/complex/uri") + .header("Content-type", "application/json") + .retrieve() + .toEntity(String.class); + Assert.assertEquals("/complex/uri", response.getBody()); + } + + @Test + public void testAnnoFrom(){ + MultiValueMap map = new LinkedMultiValueMap<>(); + map.add("name","Li"); + ResponseEntity response = RestClient.create().post() + .uri("http://" + providerAddress + ":50052/complex/annoForm") + .contentType(MediaType.APPLICATION_FORM_URLENCODED) + .body(map) + .retrieve() + .toEntity(String.class); + Assert.assertEquals("Li", response.getBody()); + } + }