Java工具类之@RequestMapping注解
一、前言
问题阐述:在某一场景下,我们的代码在 service 实现相同,但却在 controller 层访问时却希望不同的前缀可以访问。如下 :/say/hello。我们这里希望在不借助任何外部服务的情况下 通过 /a/say/hello 和 /b/say/hello 都可以访问到该接口,同时不想在 controller 中写两个方法。
二、代码实现
我们这里简单说明一下思路:
1.在 spring 服务启动后, handlermapping 的实现类 requestmappinghandlermapping
会获取到被 @requestmapping等请求注解修饰的方法,并封装成一个个 handlermethod 保存到 requestmappinghandlermapping#mappingregistry
中(handlermapping 具有多个实现类,每个实现类具有不同规则)。
2.当 dispatcherservlet 接收到请求后会根据 url 获取 合适的 handlermapping 组成 handlerexecutionchain(处理器执行链),随后通过 handleradapter 来进行请求处理。而这里通过 handlermapping 会根据请求 url 获取到匹配的 handlermethod 进行方法调用。
因此我们这里有了两种思路 :
1.在 spring 加载 handlermethod 时设置当前 handlermethod 的匹配规则为 /a/say/hello/、/b/say/hello/,当 /a/say/hello/、/b/say/hello/ 请求访问时可以与之匹配。
2.在请求处理的时候,通过拦截器将 /a/say/hello/、/b/say/hello/ 的访问路径匹配到 /say/hello 方法上。
本文选择第一种思路(不过话说怎么想都是第一种好吧)做一个简单demo示例,其实现如下:
这里需要注意 :
1.handlermapping 在 spring中有多个实现,而 dispatcherservlet.setdetectallhandlermappings(false);
参数设置spring 放弃加载多个 handlermapping,而只加载 beanname为 handlermapping 的
2.handlermapping。requestmappinginfo 包含 当前方法的诸多信息,其中就包含 什么样请求路径可以匹配到该方法,所以我们在这里获取到 requestrouter 的信息,并添加到匹配路径上。
三、效果
在 方法上加上 @requestrouter(value = {"a", "b"})
注解
/a/say/hello/
、/b/say/hello/
以及 /say/hello/
都可以访问
到此这篇关于java工具类之@requestmapping注解的文章就介绍到这了,更多相关java requestmapping内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!