mirror of
https://gitee.com/mirrors/Spring-Cloud-Alibaba.git
synced 2021-06-26 13:25:11 +08:00
Polish spring-cloud-incubator/spring-cloud-alibaba#348 : Add @PathVariable support
This commit is contained in:
parent
969dece586
commit
a150a0cec6
@ -19,7 +19,9 @@ package org.springframework.cloud.alibaba.dubbo.autoconfigure;
|
|||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||||
import org.springframework.cloud.alibaba.dubbo.service.DubboGenericServiceExecutionContextFactory;
|
import org.springframework.cloud.alibaba.dubbo.service.DubboGenericServiceExecutionContextFactory;
|
||||||
import org.springframework.cloud.alibaba.dubbo.service.DubboGenericServiceFactory;
|
import org.springframework.cloud.alibaba.dubbo.service.DubboGenericServiceFactory;
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.service.parameter.PathVariableServiceParameterResolver;
|
||||||
import org.springframework.cloud.alibaba.dubbo.service.parameter.RequestBodyServiceParameterResolver;
|
import org.springframework.cloud.alibaba.dubbo.service.parameter.RequestBodyServiceParameterResolver;
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.service.parameter.RequestHeaderServiceParameterResolver;
|
||||||
import org.springframework.cloud.alibaba.dubbo.service.parameter.RequestParamServiceParameterResolver;
|
import org.springframework.cloud.alibaba.dubbo.service.parameter.RequestParamServiceParameterResolver;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
@ -44,6 +46,8 @@ public class DubboServiceAutoConfiguration {
|
|||||||
DubboGenericServiceExecutionContextFactory.class,
|
DubboGenericServiceExecutionContextFactory.class,
|
||||||
RequestParamServiceParameterResolver.class,
|
RequestParamServiceParameterResolver.class,
|
||||||
RequestBodyServiceParameterResolver.class,
|
RequestBodyServiceParameterResolver.class,
|
||||||
|
RequestHeaderServiceParameterResolver.class,
|
||||||
|
PathVariableServiceParameterResolver.class
|
||||||
})
|
})
|
||||||
static class ParameterResolversConfiguration {
|
static class ParameterResolversConfiguration {
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,7 @@ import java.util.Set;
|
|||||||
import static org.springframework.http.HttpHeaders.COOKIE;
|
import static org.springframework.http.HttpHeaders.COOKIE;
|
||||||
import static org.springframework.util.CollectionUtils.unmodifiableMultiValueMap;
|
import static org.springframework.util.CollectionUtils.unmodifiableMultiValueMap;
|
||||||
import static org.springframework.util.StringUtils.delimitedListToStringArray;
|
import static org.springframework.util.StringUtils.delimitedListToStringArray;
|
||||||
|
import static org.springframework.util.StringUtils.hasText;
|
||||||
import static org.springframework.util.StringUtils.trimAllWhitespace;
|
import static org.springframework.util.StringUtils.trimAllWhitespace;
|
||||||
import static org.springframework.util.StringUtils.trimWhitespace;
|
import static org.springframework.util.StringUtils.trimWhitespace;
|
||||||
|
|
||||||
@ -54,11 +55,36 @@ public abstract class HttpUtils {
|
|||||||
|
|
||||||
private static final String SEMICOLON = ";";
|
private static final String SEMICOLON = ";";
|
||||||
|
|
||||||
|
private static final String QUESTION_MASK = "?";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The empty value
|
* The empty value
|
||||||
*/
|
*/
|
||||||
private static final String EMPTY_VALUE = "";
|
private static final String EMPTY_VALUE = "";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Normalize path:
|
||||||
|
* <ol>
|
||||||
|
* <li>To remove query string if presents</li>
|
||||||
|
* <li>To remove duplicated slash("/") if exists</li>
|
||||||
|
* </ol>
|
||||||
|
*
|
||||||
|
* @param path path to be normalized
|
||||||
|
* @return a normalized path if required
|
||||||
|
*/
|
||||||
|
public static String normalizePath(String path) {
|
||||||
|
if (!hasText(path)) {
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
String normalizedPath = path;
|
||||||
|
int index = normalizedPath.indexOf(QUESTION_MASK);
|
||||||
|
if (index > -1) {
|
||||||
|
normalizedPath = normalizedPath.substring(0, index);
|
||||||
|
}
|
||||||
|
return StringUtils.replace(normalizedPath, "//", "/");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get Parameters from the specified {@link HttpRequest request}
|
* Get Parameters from the specified {@link HttpRequest request}
|
||||||
*
|
*
|
||||||
|
@ -37,6 +37,7 @@ import java.util.Objects;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.SortedMap;
|
import java.util.SortedMap;
|
||||||
|
|
||||||
|
import static org.springframework.cloud.alibaba.dubbo.http.util.HttpUtils.normalizePath;
|
||||||
import static org.springframework.http.MediaType.parseMediaTypes;
|
import static org.springframework.http.MediaType.parseMediaTypes;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -83,7 +84,7 @@ public class RequestMetadata {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setPath(String path) {
|
public void setPath(String path) {
|
||||||
this.path = path;
|
this.path = normalizePath(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
public MultiValueMap<String, String> getParams() {
|
public MultiValueMap<String, String> getParams() {
|
||||||
|
@ -0,0 +1,122 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.springframework.cloud.alibaba.dubbo.service.parameter;
|
||||||
|
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.http.HttpServerRequest;
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.metadata.MethodParameterMetadata;
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.metadata.RestMethodMetadata;
|
||||||
|
import org.springframework.util.CollectionUtils;
|
||||||
|
import org.springframework.util.MultiValueMap;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static org.springframework.util.ObjectUtils.isEmpty;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract HTTP Names Value {@link DubboGenericServiceParameterResolver Dubbo GenericService Parameter Resolver}
|
||||||
|
*
|
||||||
|
* @author <a href="mailto:mercyblitz@gmail.com">Mercy</a>
|
||||||
|
*/
|
||||||
|
public abstract class AbstractNamedValueServiceParameterResolver extends AbstractDubboGenericServiceParameterResolver {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the {@link MultiValueMap} of names and values
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
protected abstract MultiValueMap<String, String> getNameAndValuesMap(HttpServerRequest request);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
||||||
|
HttpServerRequest request) {
|
||||||
|
|
||||||
|
Collection<String> names = getNames(restMethodMetadata, methodParameterMetadata);
|
||||||
|
|
||||||
|
if (isEmpty(names)) { // index can't match
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
MultiValueMap<String, String> nameAndValues = getNameAndValuesMap(request);
|
||||||
|
|
||||||
|
String targetName = null;
|
||||||
|
|
||||||
|
for (String name : names) {
|
||||||
|
if (nameAndValues.containsKey(name)) {
|
||||||
|
targetName = name;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (targetName == null) { // request parameter is abstract
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Class<?> parameterType = resolveClass(methodParameterMetadata.getType());
|
||||||
|
|
||||||
|
Object paramValue = null;
|
||||||
|
|
||||||
|
if (parameterType.isArray()) { // Array type
|
||||||
|
paramValue = nameAndValues.get(targetName);
|
||||||
|
} else {
|
||||||
|
paramValue = nameAndValues.getFirst(targetName);
|
||||||
|
}
|
||||||
|
|
||||||
|
return resolveValue(paramValue, parameterType);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
||||||
|
RestMethodMetadata clientRestMethodMetadata, Object[] arguments) {
|
||||||
|
|
||||||
|
Collection<String> names = getNames(restMethodMetadata, methodParameterMetadata);
|
||||||
|
|
||||||
|
if (isEmpty(names)) { // index can't match
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Integer index = null;
|
||||||
|
|
||||||
|
Map<Integer, Collection<String>> clientIndexToName = clientRestMethodMetadata.getIndexToName();
|
||||||
|
|
||||||
|
for (Map.Entry<Integer, Collection<String>> entry : clientIndexToName.entrySet()) {
|
||||||
|
|
||||||
|
Collection<String> clientParamNames = entry.getValue();
|
||||||
|
|
||||||
|
if (CollectionUtils.containsAny(names, clientParamNames)) {
|
||||||
|
index = entry.getKey();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return index > -1 ? arguments[index] : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Collection<String> getNames(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata) {
|
||||||
|
|
||||||
|
Map<Integer, Collection<String>> indexToName = restMethodMetadata.getIndexToName();
|
||||||
|
|
||||||
|
int index = methodParameterMetadata.getIndex();
|
||||||
|
|
||||||
|
Collection<String> paramNames = indexToName.get(index);
|
||||||
|
|
||||||
|
return paramNames == null ? Collections.emptyList() : paramNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.springframework.cloud.alibaba.dubbo.service.parameter;
|
||||||
|
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.http.HttpServerRequest;
|
||||||
|
import org.springframework.util.MultiValueMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HTTP Request Path Variable {@link DubboGenericServiceParameterResolver Dubbo GenericService Parameter Resolver}
|
||||||
|
*
|
||||||
|
* @author <a href="mailto:mercyblitz@gmail.com">Mercy</a>
|
||||||
|
*/
|
||||||
|
public class PathVariableServiceParameterResolver extends AbstractNamedValueServiceParameterResolver {
|
||||||
|
|
||||||
|
public static final int DEFAULT_ORDER = 3;
|
||||||
|
|
||||||
|
public PathVariableServiceParameterResolver() {
|
||||||
|
super();
|
||||||
|
setOrder(DEFAULT_ORDER);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected MultiValueMap<String, String> getNameAndValuesMap(HttpServerRequest request) {
|
||||||
|
return request.getQueryParams();
|
||||||
|
}
|
||||||
|
}
|
@ -106,6 +106,12 @@ public class RequestBodyServiceParameterResolver extends AbstractDubboGenericSer
|
|||||||
@Override
|
@Override
|
||||||
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
||||||
RestMethodMetadata clientRestMethodMetadata, Object[] arguments) {
|
RestMethodMetadata clientRestMethodMetadata, Object[] arguments) {
|
||||||
|
|
||||||
|
if (!supportParameter(restMethodMetadata, methodParameterMetadata)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Integer clientBodyIndex = clientRestMethodMetadata.getBodyIndex();
|
||||||
|
return arguments[clientBodyIndex];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership.
|
||||||
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
||||||
|
* (the "License"); you may not use this file except in compliance with
|
||||||
|
* the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.springframework.cloud.alibaba.dubbo.service.parameter;
|
||||||
|
|
||||||
|
import org.springframework.cloud.alibaba.dubbo.http.HttpServerRequest;
|
||||||
|
import org.springframework.util.MultiValueMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HTTP Request Header {@link DubboGenericServiceParameterResolver Dubbo GenericService Parameter Resolver}
|
||||||
|
*
|
||||||
|
* @author <a href="mailto:mercyblitz@gmail.com">Mercy</a>
|
||||||
|
*/
|
||||||
|
public class RequestHeaderServiceParameterResolver extends AbstractNamedValueServiceParameterResolver {
|
||||||
|
|
||||||
|
public static final int DEFAULT_ORDER = 9;
|
||||||
|
|
||||||
|
public RequestHeaderServiceParameterResolver() {
|
||||||
|
super();
|
||||||
|
setOrder(DEFAULT_ORDER);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected MultiValueMap<String, String> getNameAndValuesMap(HttpServerRequest request) {
|
||||||
|
return request.getHeaders();
|
||||||
|
}
|
||||||
|
}
|
@ -17,23 +17,14 @@
|
|||||||
package org.springframework.cloud.alibaba.dubbo.service.parameter;
|
package org.springframework.cloud.alibaba.dubbo.service.parameter;
|
||||||
|
|
||||||
import org.springframework.cloud.alibaba.dubbo.http.HttpServerRequest;
|
import org.springframework.cloud.alibaba.dubbo.http.HttpServerRequest;
|
||||||
import org.springframework.cloud.alibaba.dubbo.metadata.MethodParameterMetadata;
|
|
||||||
import org.springframework.cloud.alibaba.dubbo.metadata.RestMethodMetadata;
|
|
||||||
import org.springframework.util.CollectionUtils;
|
|
||||||
import org.springframework.util.MultiValueMap;
|
import org.springframework.util.MultiValueMap;
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import static org.springframework.util.ObjectUtils.isEmpty;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* HTTP Request Parameter {@link DubboGenericServiceParameterResolver Dubbo GenericService Parameter Resolver}
|
* HTTP Request Parameter {@link DubboGenericServiceParameterResolver Dubbo GenericService Parameter Resolver}
|
||||||
*
|
*
|
||||||
* @author <a href="mailto:mercyblitz@gmail.com">Mercy</a>
|
* @author <a href="mailto:mercyblitz@gmail.com">Mercy</a>
|
||||||
*/
|
*/
|
||||||
public class RequestParamServiceParameterResolver extends AbstractDubboGenericServiceParameterResolver {
|
public class RequestParamServiceParameterResolver extends AbstractNamedValueServiceParameterResolver {
|
||||||
|
|
||||||
public static final int DEFAULT_ORDER = 1;
|
public static final int DEFAULT_ORDER = 1;
|
||||||
|
|
||||||
@ -43,80 +34,7 @@ public class RequestParamServiceParameterResolver extends AbstractDubboGenericSe
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
protected MultiValueMap<String, String> getNameAndValuesMap(HttpServerRequest request) {
|
||||||
HttpServerRequest request) {
|
return request.getQueryParams();
|
||||||
|
|
||||||
Collection<String> paramNames = getParamNames(restMethodMetadata, methodParameterMetadata);
|
|
||||||
|
|
||||||
if (isEmpty(paramNames)) { // index can't match
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MultiValueMap<String, String> queryParams = request.getQueryParams();
|
|
||||||
|
|
||||||
String targetParamName = null;
|
|
||||||
|
|
||||||
for (String paramName : paramNames) {
|
|
||||||
if (queryParams.containsKey(paramName)) {
|
|
||||||
targetParamName = paramName;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (targetParamName == null) { // request parameter is abstract
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
Class<?> parameterType = resolveClass(methodParameterMetadata.getType());
|
|
||||||
|
|
||||||
Object paramValue = null;
|
|
||||||
|
|
||||||
if (parameterType.isArray()) { // Array type
|
|
||||||
paramValue = queryParams.get(targetParamName);
|
|
||||||
} else {
|
|
||||||
paramValue = queryParams.getFirst(targetParamName);
|
|
||||||
}
|
|
||||||
|
|
||||||
return resolveValue(paramValue, parameterType);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Object resolve(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata,
|
|
||||||
RestMethodMetadata clientRestMethodMetadata, Object[] arguments) {
|
|
||||||
|
|
||||||
Collection<String> paramNames = getParamNames(restMethodMetadata, methodParameterMetadata);
|
|
||||||
|
|
||||||
if (isEmpty(paramNames)) { // index can't match
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
Integer index = null;
|
|
||||||
|
|
||||||
Map<Integer, Collection<String>> clientIndexToName = clientRestMethodMetadata.getIndexToName();
|
|
||||||
|
|
||||||
for (Map.Entry<Integer, Collection<String>> entry : clientIndexToName.entrySet()) {
|
|
||||||
|
|
||||||
Collection<String> clientParamNames = entry.getValue();
|
|
||||||
|
|
||||||
if (CollectionUtils.containsAny(paramNames, clientParamNames)) {
|
|
||||||
index = entry.getKey();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return index > -1 ? arguments[index] : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private Collection<String> getParamNames(RestMethodMetadata restMethodMetadata, MethodParameterMetadata methodParameterMetadata) {
|
|
||||||
|
|
||||||
Map<Integer, Collection<String>> indexToName = restMethodMetadata.getIndexToName();
|
|
||||||
|
|
||||||
int index = methodParameterMetadata.getIndex();
|
|
||||||
|
|
||||||
Collection<String> paramNames = indexToName.get(index);
|
|
||||||
|
|
||||||
return paramNames == null ? Collections.emptyList() : paramNames;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -33,14 +33,21 @@ import org.springframework.context.annotation.Bean;
|
|||||||
import org.springframework.context.annotation.Lazy;
|
import org.springframework.context.annotation.Lazy;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
import org.springframework.web.bind.annotation.RequestHeader;
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
import org.springframework.web.client.RestTemplate;
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
|
||||||
|
import javax.ws.rs.GET;
|
||||||
|
import javax.ws.rs.Path;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static org.springframework.http.MediaType.APPLICATION_JSON_UTF8_VALUE;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dubbo Spring Cloud Bootstrap
|
* Dubbo Spring Cloud Bootstrap
|
||||||
*/
|
*/
|
||||||
@ -65,21 +72,6 @@ public class DubboSpringCloudBootstrap {
|
|||||||
@LoadBalanced
|
@LoadBalanced
|
||||||
private RestTemplate restTemplate;
|
private RestTemplate restTemplate;
|
||||||
|
|
||||||
@GetMapping(value = "/dubbo/call/echo")
|
|
||||||
public String dubboEcho(@RequestParam("message") String message) {
|
|
||||||
return restService.param(message);
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping(value = "/feign/call/echo")
|
|
||||||
public String feignEcho(@RequestParam("message") String message) {
|
|
||||||
return feignRestService.param(message);
|
|
||||||
}
|
|
||||||
|
|
||||||
@GetMapping(value = "/feign-dubbo/call/echo")
|
|
||||||
public String feignDubboEcho(@RequestParam("message") String message) {
|
|
||||||
return dubboFeignRestService.param(message);
|
|
||||||
}
|
|
||||||
|
|
||||||
@FeignClient("spring-cloud-alibaba-dubbo")
|
@FeignClient("spring-cloud-alibaba-dubbo")
|
||||||
public interface FeignRestService {
|
public interface FeignRestService {
|
||||||
|
|
||||||
@ -89,6 +81,20 @@ public class DubboSpringCloudBootstrap {
|
|||||||
@PostMapping("/params")
|
@PostMapping("/params")
|
||||||
public String params(@RequestParam("b") String b, @RequestParam("a") int a);
|
public String params(@RequestParam("b") String b, @RequestParam("a") int a);
|
||||||
|
|
||||||
|
@PostMapping(value = "/request/body/map", produces = APPLICATION_JSON_UTF8_VALUE)
|
||||||
|
User requestBody(@RequestParam("param") String param, @RequestBody Map<String, Object> data);
|
||||||
|
|
||||||
|
@GetMapping("/headers")
|
||||||
|
@Path("/headers")
|
||||||
|
@GET
|
||||||
|
public String headers(@RequestHeader("h2") String header2,
|
||||||
|
@RequestHeader("h") String header,
|
||||||
|
@RequestParam("v") Integer value);
|
||||||
|
|
||||||
|
@GetMapping("/path-variables/{p1}/{p2}")
|
||||||
|
public String pathVariables(@PathVariable("p2") String path2,
|
||||||
|
@PathVariable("p1") String path1,
|
||||||
|
@RequestParam("v") String param);
|
||||||
}
|
}
|
||||||
|
|
||||||
@FeignClient("spring-cloud-alibaba-dubbo")
|
@FeignClient("spring-cloud-alibaba-dubbo")
|
||||||
@ -99,7 +105,22 @@ public class DubboSpringCloudBootstrap {
|
|||||||
String param(@RequestParam("param") String param);
|
String param(@RequestParam("param") String param);
|
||||||
|
|
||||||
@PostMapping("/params")
|
@PostMapping("/params")
|
||||||
public String params(@RequestParam("b") String paramB, @RequestParam("a") int paramA);
|
String params(@RequestParam("b") String paramB, @RequestParam("a") int paramA);
|
||||||
|
|
||||||
|
@PostMapping(value = "/request/body/map", produces = APPLICATION_JSON_UTF8_VALUE)
|
||||||
|
User requestBody(@RequestParam("param") String param, @RequestBody Map<String, Object> data);
|
||||||
|
|
||||||
|
@GetMapping("/headers")
|
||||||
|
@Path("/headers")
|
||||||
|
@GET
|
||||||
|
public String headers(@RequestHeader("h2") String header2,
|
||||||
|
@RequestParam("v") Integer value,
|
||||||
|
@RequestHeader("h") String header);
|
||||||
|
|
||||||
|
@GetMapping("/path-variables/{p1}/{p2}")
|
||||||
|
public String pathVariables(@RequestParam("v") String param,
|
||||||
|
@PathVariable("p2") String path2,
|
||||||
|
@PathVariable("p1") String path1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -107,24 +128,76 @@ public class DubboSpringCloudBootstrap {
|
|||||||
public ApplicationRunner paramRunner() {
|
public ApplicationRunner paramRunner() {
|
||||||
return arguments -> {
|
return arguments -> {
|
||||||
|
|
||||||
|
// To call /path-variables
|
||||||
|
callPathVariables();
|
||||||
|
|
||||||
|
// To call /headers
|
||||||
|
callHeaders();
|
||||||
|
|
||||||
// To call /param
|
// To call /param
|
||||||
|
callParam();
|
||||||
|
|
||||||
|
// To call /params
|
||||||
|
callParams();
|
||||||
|
|
||||||
|
// To call /request/body/map
|
||||||
|
callRequestBodyMap();
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private void callPathVariables() {
|
||||||
|
// Dubbo Service call
|
||||||
|
System.out.println(restService.pathVariables("a", "b", "c"));
|
||||||
|
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
||||||
|
System.out.println(dubboFeignRestService.pathVariables("c", "b", "a"));
|
||||||
|
// Spring Cloud Open Feign REST Call
|
||||||
|
System.out.println(feignRestService.pathVariables("b", "a", "c"));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void callHeaders() {
|
||||||
|
// Dubbo Service call
|
||||||
|
System.out.println(restService.headers("a", "b", 10));
|
||||||
|
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
||||||
|
System.out.println(dubboFeignRestService.headers("b", 10, "a"));
|
||||||
|
// Spring Cloud Open Feign REST Call
|
||||||
|
System.out.println(feignRestService.headers("b", "a", 10));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void callParam() {
|
||||||
// Dubbo Service call
|
// Dubbo Service call
|
||||||
System.out.println(restService.param("mercyblitz"));
|
System.out.println(restService.param("mercyblitz"));
|
||||||
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
||||||
System.out.println(dubboFeignRestService.param("mercyblitz"));
|
System.out.println(dubboFeignRestService.param("mercyblitz"));
|
||||||
// Spring Cloud Open Feign REST Call
|
// Spring Cloud Open Feign REST Call
|
||||||
System.out.println(feignRestService.param("mercyblitz"));
|
System.out.println(feignRestService.param("mercyblitz"));
|
||||||
|
}
|
||||||
|
|
||||||
// To call /params
|
private void callParams() {
|
||||||
// Dubbo Service call
|
// Dubbo Service call
|
||||||
System.out.println(restService.params(1, "1"));
|
System.out.println(restService.params(1, "1"));
|
||||||
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
||||||
System.out.println(dubboFeignRestService.params("1", 1));
|
System.out.println(dubboFeignRestService.params("1", 1));
|
||||||
// Spring Cloud Open Feign REST Call
|
// Spring Cloud Open Feign REST Call
|
||||||
System.out.println(feignRestService.params("1", 1));
|
System.out.println(feignRestService.params("1", 1));
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void callRequestBodyMap() {
|
||||||
|
|
||||||
|
Map<String, Object> data = new HashMap<>();
|
||||||
|
data.put("id", 1);
|
||||||
|
data.put("name", "小马哥");
|
||||||
|
data.put("age", 33);
|
||||||
|
|
||||||
|
// Dubbo Service call
|
||||||
|
System.out.println(restService.requestBody(data, "Hello,World"));
|
||||||
|
// Spring Cloud Open Feign REST Call (Dubbo Transported)
|
||||||
|
System.out.println(dubboFeignRestService.requestBody("Hello,World", data));
|
||||||
|
// Spring Cloud Open Feign REST Call
|
||||||
|
System.out.println(feignRestService.requestBody("Hello,World", data));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public ApplicationRunner restTemplateRunner() {
|
public ApplicationRunner restTemplateRunner() {
|
||||||
return arguments -> {
|
return arguments -> {
|
||||||
@ -136,11 +209,11 @@ public class DubboSpringCloudBootstrap {
|
|||||||
data.put("id", 1);
|
data.put("id", 1);
|
||||||
data.put("name", "小马哥");
|
data.put("name", "小马哥");
|
||||||
data.put("age", 33);
|
data.put("age", 33);
|
||||||
User user = restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/setBody/map", data, User.class);
|
User user = restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/body/map", data, User.class);
|
||||||
|
|
||||||
System.out.println(restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/setBody/map", data, String.class));
|
System.out.println(restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/body/map", data, String.class));
|
||||||
|
|
||||||
Map map = restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/setBody/user", user, Map.class);
|
Map map = restTemplate.postForObject("http://spring-cloud-alibaba-dubbo/request/body/user", user, Map.class);
|
||||||
System.out.println(map);
|
System.out.println(map);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -25,17 +25,18 @@ import java.util.Map;
|
|||||||
*/
|
*/
|
||||||
public interface RestService {
|
public interface RestService {
|
||||||
|
|
||||||
String param(String message);
|
String param(String param);
|
||||||
|
|
||||||
String params(int a, String b);
|
String params(int a, String b);
|
||||||
|
|
||||||
User requestBody(Map<String, Object> data);
|
String headers(String header, String header2, Integer param);
|
||||||
|
|
||||||
Map<String, Object> requestBody(User user);
|
String pathVariables(String path1, String path2, String param);
|
||||||
|
|
||||||
String header(String header);
|
|
||||||
|
|
||||||
String form(String form);
|
String form(String form);
|
||||||
|
|
||||||
String cookie(String userAgent);
|
User requestBody(Map<String, Object> data, String param);
|
||||||
|
|
||||||
|
Map<String, Object> requestBody(User user);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,8 +20,8 @@ import com.alibaba.dubbo.rpc.RpcContext;
|
|||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.web.bind.annotation.CookieValue;
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
import org.springframework.web.bind.annotation.RequestHeader;
|
import org.springframework.web.bind.annotation.RequestHeader;
|
||||||
@ -29,12 +29,12 @@ import org.springframework.web.bind.annotation.RequestParam;
|
|||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import javax.ws.rs.Consumes;
|
import javax.ws.rs.Consumes;
|
||||||
import javax.ws.rs.CookieParam;
|
|
||||||
import javax.ws.rs.FormParam;
|
import javax.ws.rs.FormParam;
|
||||||
import javax.ws.rs.GET;
|
import javax.ws.rs.GET;
|
||||||
import javax.ws.rs.HeaderParam;
|
import javax.ws.rs.HeaderParam;
|
||||||
import javax.ws.rs.POST;
|
import javax.ws.rs.POST;
|
||||||
import javax.ws.rs.Path;
|
import javax.ws.rs.Path;
|
||||||
|
import javax.ws.rs.PathParam;
|
||||||
import javax.ws.rs.Produces;
|
import javax.ws.rs.Produces;
|
||||||
import javax.ws.rs.QueryParam;
|
import javax.ws.rs.QueryParam;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -74,13 +74,32 @@ public class StandardRestService implements RestService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@GetMapping("/header")
|
@GetMapping("/headers")
|
||||||
@Path("/header")
|
@Path("/headers")
|
||||||
@GET
|
@GET
|
||||||
public String header(@RequestHeader("h") @HeaderParam("h") String header) {
|
public String headers(@RequestHeader("h") @HeaderParam("h") String header,
|
||||||
return String.valueOf(header);
|
@RequestHeader("h2") @HeaderParam("h2") String header2,
|
||||||
|
@RequestParam("v") @QueryParam("v") Integer param) {
|
||||||
|
String result = header + " , " + header2 + " , " + param;
|
||||||
|
log("/headers", result);
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@GetMapping("/path-variables/{p1}/{p2}")
|
||||||
|
@Path("/path-variables/{p1}/{p2}")
|
||||||
|
@GET
|
||||||
|
public String pathVariables(@PathVariable("p1") @PathParam("p1") String path1,
|
||||||
|
@PathVariable("p2") @PathParam("p2") String path2,
|
||||||
|
@RequestParam("v") @QueryParam("v") String param) {
|
||||||
|
String result = path1 + " , " + path2 + " , " + param;
|
||||||
|
log("/path-variables", result);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
// @CookieParam does not support : https://github.com/OpenFeign/feign/issues/913
|
||||||
|
// @CookieValue also does not support
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@PostMapping("/form")
|
@PostMapping("/form")
|
||||||
@Path("/form")
|
@Path("/form")
|
||||||
@ -94,11 +113,12 @@ public class StandardRestService implements RestService {
|
|||||||
@Path("/request/setBody/map")
|
@Path("/request/setBody/map")
|
||||||
@POST
|
@POST
|
||||||
@Produces(APPLICATION_JSON_VALUE)
|
@Produces(APPLICATION_JSON_VALUE)
|
||||||
public User requestBody(@RequestBody Map<String, Object> data) {
|
public User requestBody(@RequestBody Map<String, Object> data, @RequestParam("param") @QueryParam("param") String param) {
|
||||||
User user = new User();
|
User user = new User();
|
||||||
user.setId(((Integer) data.get("id")).longValue());
|
user.setId(((Integer) data.get("id")).longValue());
|
||||||
user.setName((String) data.get("name"));
|
user.setName((String) data.get("name"));
|
||||||
user.setAge((Integer) data.get("age"));
|
user.setAge((Integer) data.get("age"));
|
||||||
|
log("/request/body/map", param);
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -115,14 +135,6 @@ public class StandardRestService implements RestService {
|
|||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
@GetMapping("/cookie")
|
|
||||||
@Path("/cookie")
|
|
||||||
@GET
|
|
||||||
public String cookie(@CookieParam("User-Agent") @CookieValue("User-Agent") String userAgent) {
|
|
||||||
return userAgent;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void log(String url, Object result) {
|
private void log(String url, Object result) {
|
||||||
String message = String.format("The client[%s] uses '%s' protocol to call %s : %s",
|
String message = String.format("The client[%s] uses '%s' protocol to call %s : %s",
|
||||||
RpcContext.getContext().getRemoteHostName(),
|
RpcContext.getContext().getRemoteHostName(),
|
||||||
|
@ -7,6 +7,8 @@ spring:
|
|||||||
server-addr: 127.0.0.1:8848
|
server-addr: 127.0.0.1:8848
|
||||||
config:
|
config:
|
||||||
server-addr: 127.0.0.1:8848
|
server-addr: 127.0.0.1:8848
|
||||||
|
main:
|
||||||
|
allow-bean-definition-overriding: true
|
||||||
|
|
||||||
eureka:
|
eureka:
|
||||||
client:
|
client:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user