zoukankan      html  css  js  c++  java
  • Spring MVC DispatcherServlet改造为 CSE RestServlet 常见问题汇编

    【摘要】 本文是使用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

  • 相关阅读:
    php RabbitMQ使用
    phalcon: 开启模板缓存和缓存路径
    phalcon:整合官方多模块功能,方便多表查询
    mysql: 模糊查询 feild like keyword or feild like keyword , concat(feild1,feild2,feild3) like keyword
    php的http数据传输get/post...
    java大数字操作:BigInteger,BigDecimal(浮点型)
    DecimalFormat数据格式函数
    MySQL比like语句更高效的写法locate position instr find_in_set
    mysql中使用instr替换like
    mysql中的多行查询结果合并成一个
  • 原文地址:https://www.cnblogs.com/2020-zhy-jzoj/p/13165781.html
Copyright © 2011-2022 走看看