【摘要】 本文是使用CSE RestServlet替换Spring MVC DispatcherServlet常见问题汇总。
将Spring Boot的REST应用改造为CSE的REST应用的核心部分就是使用CSE RestServlet替换Spring MVC DispatcherServlet。有很多文章介绍了相关工作量评估、替换原理、改造步骤等。比如:
[改造原理和步骤] 在Spring Boot中使用CSE
[改造工作量评估] 微服务改造设计参考
[改造步骤和实践] 基于Spring Boot 2.0的IoT应用集成和使用CSE实践
本文主要是常见问题汇总。
问题摘要:使用RequestMapping定义多个Path
问题描述:
@RequestMapping(value = {"/v3-ext/agencies", "/v3-huawei/agencies", "/v3.0/OS-AGENCY/agencies"},
method = RequestMethod.GET, produces = "application/json;charset=UTF-8")
public Map<String, Object> listAgency(@RequestParam("domain_id") String domainId)
以上接口定义了多个Path。在CSE中,一个接口只能允许一个Path,并且必须存在唯一的operation id。默认情况下operation id就是方法名。
错误日志:
解决建议:
可以将一个接口拆分为多个接口。
@RequestMapping(value = {"/v3-ext/agencies"},
method = RequestMethod.GET, produces = "application/json;charset=UTF-8")
public Map<String, Object> listAgency1(@RequestParam("domain_id") String domainId)
@RequestMapping(value = {"/v3.0/OS-AGENCY/agencies"},
method = RequestMethod.GET, produces = "application/json;charset=UTF-8")
public Map<String, Object> listAgency2(@RequestParam("domain_id") String domainId)
问题摘要:不支持在接口参数里面使用HttpServletResponse
问题描述:
@RequestMapping(value = "/v3/groups/{group_id}/users/{user_id}", method = RequestMethod.HEAD, produces = "application/json;charset=UTF-8")
public void isUserOfGroup(@PathVariable("group_id") String groupId,
@PathVariable("user_id") String userId, HttpServletResponse response)
以上接口使用了HttpServletResponse作为接口参数。CSE的通信层与编码层是完全解耦的,业务代码不能直接操作通信层的响应。另外,CSE要求所有接口都需要有明确的定义(即契约,swagger),开发的时候,接口定义即文档。
错误日志:
解决建议:
这种情况需要试业务逻辑进行分析,将操作response的内容抽取为响应值。比如:
response.setStatus(resultCode)
这种代码只是想设置响应的错误码,可以替换为下面的方式:
@RequestMapping(value = "/v3/groups/{group_id}/users/{user_id}", method = RequestMethod.HEAD, produces = "application/json;charset=UTF-8")
@ApiResponses({
@ApiResponse(code = 200, response = String.class, message = ""),@ApiResponse(code = 204, response = String.class, message = "")
})
public Response isUserOfGroup(@PathVariable("group_id") String groupId,
@PathVariable("user_id") String userId) throws BadRequestException {
if(groupService.isUserOfGroup(groupId, userId)) {
return Response.create(javax.ws.rs.core.Response.Status.OK, "");
} else {
return Response.create(javax.ws.rs.core.Response.Status.NO_CONTENT, "");
}
}
问题摘要:参数数据类型里面包含抽象数据结构
问题描述:
@RequestMapping(value = "/v3/regions/{region_id}", method = RequestMethod.GET, produces="application/json;charset=UTF-8")
public Map<String, Region> getRegion(@PathVariable("region_id") String regionId)
其中Region类包含字段locales是Map,没有具体类型。
public class Region {
private String id;
private String description;
private String parent_region_id;
private String type;
private Map locales;
private Links links;
错误日志:
解决建议:
这种情况是具体情况修改为具体类型即可,比如Map<String,String>,或者修改为Object。
来源:华为云社区 作者:liubao68