spring 实现 restful API 遇到一个路径中需要解析数字 ID 导致其他接口路由错误的问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
shadowfish0

spring 实现 restful API 遇到一个路径中需要解析数字 ID 导致其他接口路由错误的问题

  •  
  •   shadowfish0 2021 年 8 月 31 日 1491 次点击
    这是一个创建于 1697 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如我有一个接口 /news/{id}

    这个 ID 是 int,我直接在方法体中用了 Integer 类型,同时配置了如果类型转换失败就统一进参数错误处理,返回 400 (这里是因为其他不使用 path 变量的校验中也要用到这个)

    但是问题来了,如果这个 id 不是 int

    /news/ssss

    它并不会返回应有的 404 错误,而是直接进了参数处理过程返回 400

    这就不对了,想问问应该如何解决这个问题

    10 条回复    2021-09-02 12:05:51 +08:00
    hhyyd
        1
    hhyyd  
       2021 年 8 月 31 日
    我觉得没什么问题.

    springmvc 在匹配的时候,先匹配确定的 url, 如果没有那就去匹配 带通配符的 /news/{id}.

    因为 url 是 string 所以确实匹配到了 /news/ssss=>/news/{id}. 没有 404 NotFound, 它确实找到了 url.

    然后在类型转换的时候 400 错误了.
    zxCoder
        2
    zxCoder  
       2021 年 8 月 31 日
    "应有的 404 错误",好像要说 400 也没什么不对吧
    hhyyd
        3
    hhyyd  
       2021 年 8 月 31 日
    如果想让这个匹配不到,我的思路是:

    自定义 HandlerMapping 在匹配到 HandlerMethod 之后, 尝试一次参数的类型匹配?转换?, 如果匹配失败, 直接让这个 url 匹配不到从而走 noHandlerFound 的逻辑抛 404

    不知道是否可行?
    qinxi
        4
    qinxi  
       2021 年 8 月 31 日
    return ResponseEntity.notFound()
    Vegetable
        5
    Vegetable  
       2021 年 8 月 31 日
    这不就是类型转换失败嘛?不然你那个转换失败处理的是啥?
    Kilerd
        7
    Kilerd  
       2021 年 8 月 31 日   4
    @GetMapping("/news/{id:[0-9]+})
    aragakiyuii
        8
    aragakiyuii  
       2021 年 8 月 31 日
    我觉得是接口设计问题,看看 AntPathMatcher 这个类
    shadowfish0
        9
    shadowfish0  
    OP
       2021 年 9 月 2 日
    @Kilerd 感谢,这种方法完美解决
    shadowfish0
        10
    shadowfish0  
    OP
       2021 年 9 月 2 日
    @hhyyd 感谢回复,楼下的正则方式感觉更加简单,直接通过让 url 匹配不到的方式解决这个问题嘿。但还是感谢大佬回复!
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1126 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 64ms UTC 18:11 PVG 02:11 LAX 11:11 JFK 14:11
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86