@RequestMapping是怎么处理映射的?
创始人
2025-06-01 13:46:54

在享受了@RequestMapping方便的处理映射时,忍不住会开始好奇,

  • 这个注解怎么就能找到我的接口?
  • @RequestMapping到底替我做了什么事?

今天来解答如上两个问题。

画了个比较难看的图,不过都是老生常谈了,逻辑都是熟悉的。
在这里插入图片描述
SpringMVC在处理一个请求时,会首先通过请求头中的Request URL中的信息,查找Spring的映射处理器,顾名思义,既然是映射,那么一定存在一个键值对,存在一一对应的关系。

那我来找一下这个映射保存在哪里了。

在这里插入图片描述
由于是学习DispatcherServlet,就直接写个简单的SpringBoot程序,打上断点,在idea的debug模式中,查看调用链,或者叫有的人称呼为栈帧。
在这里明显发现,在进入接口前(从上往下观察调用链),经历了好几次的反射,然后是RequestMappingHandlerAdapter(这个类比较重要等一下聊),再然后是DispatcherServlet。

马上点进DispatcherServlet,发现一行亲切的注释。

在这里插入图片描述

原来这里就是实际调用处理程序的地方。

检查一下变量,发现这个处理程序就是我的接口,证明映射已经找好了。

在这里插入图片描述

我今天要查的是@RequestMapping是怎么找到我接口的,所以往上翻,查查这个mappedHandler到底是怎么来的。

在这里插入图片描述
翻了几行就看到了,而且也有一行亲切的注释。

// Determine handler for the current request.
mappedHandler = getHandler(processedRequest);

确定当前请求的处理程序。
很明显,就它了。继续点进去看。

在这里插入图片描述
这是一条比较长的调用链,中间过程就跳过了,直接看结果。
urlPath就是从Request Header中提取的URL。
pathLookup则是我这个程序中的全部接口的路径。
可以发现这个就是最开始的图中,处理映射的关键部分了。
SpringMVC通过维护pathLookup这个Map来处理URL与接口的映射关系。

在这里插入图片描述
但是又有一个问题,这不是一对一呀。MultiValueMap明显是一个key对应几个value的结构。
写过bug的都知道,一个程序中,@RequestMapping写重复了是起不来项目的。
在这里插入图片描述

为什么SpringMVC要选择这种结构呢?等下面再分析。

解决了@RequestMapping是怎么找到我的接口的问题了

现在想知道,@RequestMapping为了能找到我的接口,背地里都做了些什么

为了了解pathLookup的初始化过程,就必须要了解SpringMVC的加载过程。
在这里插入图片描述
还是看AbstractHandlerMethodMapping,这里发现是一个循环中添加的。
而且在register方法632行,居然还加了读写锁的写锁,什么情况,难道这里还有并发问题?
先留下问题继续Alt+F7查上游调用链。
(这里补充一点,Alt+F7不好使多半是GeForce Experience的游戏内覆盖模块占用了快捷键,建议改一下或者干脆关掉)
在register内打上断点,重启项目,发现进断点了,看一下调用链。
在这里插入图片描述
又引出一个类,RequestMappingHandlerMapping。
跟刚才关注的RequestMappingHandlerAdapter长得可以说是如同亲兄弟。
由于个人水平有限和篇幅原因,这两兄弟只能在下篇文章中聊一下个人的简单认识。

从上图中的调用链可以看出,最终调用是在afterPropertiesSet。
这是一个InitializingBean接口中的方法,实现了InitializingBean的类必须重写afterPropertiesSet,而afterPropertiesSet将会在类实例化以后立刻调用。

而在AbstractHandlerMethodMapping的afterPropertiesSet中调用的是initHandlerMethods。
在这里插入图片描述
注释说的很明白,这里做两件事,第一件事是扫描所有的bean,第二件事是注册处理程序,也就是刚刚聊的建立映射关系。
通过ApplicationContext获取到所有Object类的子类,可以看到包含了程序中的controller。
在这里插入图片描述

再判断是否是被@Controller或者是@RequestMapping修饰的bean,由于暴露的接口通常都必须被@Controller或者是@RequestMapping修饰,所以可以理解为筛选需要建立映射的bean。
在这里插入图片描述

回到RequestMappingHandlerMapping的实现方法。
在这里插入图片描述
继续步进看实现。
在这里插入图片描述
需要注意的是这里的MethodIntrospector.MetadataLookup是一个@FunctionalInterface,所以这里的匿名实现不包含函数名。
MethodIntrospector.selectMethods返回的map,就是这个类中所有被@RequestMapping修饰的方法。key为Method对象,value是RequestMappingInfo。
RequestMappingInfo可以理解为RequestMapping的实体类,对我们有用的信息是其中包含的pathPattern,也就是@RequestMapping的value。
在这里插入图片描述

在获取了bean中包含的@RequestMapping修饰的方法后,又回到了之前的register,将使用RequestMappingInfo中的信息,为pathLookup赋值,这样一来,当请求进入程序时,就能够找到正确的接口了。

再回顾一下SpringMVC中bean的生命周期。
再拿一张小图做参考。

实例化填充属性调用BeanNameAware的setBeanName方法调用BeanFactoryAware的setBeanFactory方法调用ApplicationContextAware的setApplicationContext方法调用BeanPostProcessor的预初始化方法调用InitializingBean的afterProperitiesSet方法调用自定义的初始化方法调用BeanPostProcessor的初始化后方法bean可以使用了

总结一下,@RequestMapping的初始化过程应当理解为:

@RequestMapping通过pathLookup维护了一个MultiValueMap类型的变量pathLookup,pathLookup是通过RequestMappingHandlerMapping初始化的,而这个初始化的过程发生在Spring容器初始化bean的过程中。

相关内容

热门资讯

漂移是什么意思(摇杆漂移是什么... 本篇文章极速百科给大家谈谈漂移是什么意思,以及摇杆漂移是什么意思对应的知识点,希望对各位有所帮助,不...
车架号后四位是什么(车架号后四... 本篇文章极速百科给大家谈谈车架号后四位是什么,以及车架号后四位是什么在哪里看对应的知识点,希望对各位...
隐形眼镜基弧是什么意思,请问,... 隐形眼镜基弧是什么意思目录隐形眼镜基弧是什么意思请问,配隐形眼镜的时候要不要关注那个基弧?隐形眼镜基...
广西省崇左市属于什么市,祟左是... 广西省崇左市属于什么市目录广西省崇左市属于什么市祟左是地级市还是县级市崇左是南宁得直辖市吗 为什么区...
内衣尺码大小分类,内衣的型号分... 内衣尺码大小分类目录内衣尺码大小分类内衣的型号分哪几种?什么abc事什么意思?34、36是尺寸嘛?内...
几个防止卫生间反味小妙招,卫生... 几个防止卫生间反味小妙招目录几个防止卫生间反味小妙招卫生间反臭怎么办?卫生间怎么样防臭几个防止卫生间...
庄子中的成语和解释,四个出自《... 庄子中的成语和解释目录庄子中的成语和解释四个出自《庄子》的成语及解释《庄子》中的成语及解释(按篇目分...
怎么切翡翠原石(收玉石的联系方... 本篇文章极速百科给大家谈谈怎么切翡翠原石,以及收玉石的联系方式对应的知识点,希望对各位有所帮助,不要...
关于燕子的古诗,描写燕子的古诗... 关于燕子的古诗目录关于燕子的古诗描写燕子的古诗描写燕子的古诗有哪些?关于燕子的古诗关于燕子的古诗 ...
好巧不巧是什么意思,好巧不巧什... 好巧不巧是什么意思目录好巧不巧是什么意思好巧不巧什么意思?“无巧不巧”究竟何解?好巧不巧是什么意思好...
关东煮里面放什么配料啊,关东煮... 关东煮里面放什么配料啊目录关东煮里面放什么配料啊关东煮的配料关东煮需要哪些调味料呀?请问,关东煮都可...
极速进化满电出发!长安深蓝SL... 本篇文章极速百科给大家谈谈极速进化满电出发!长安深蓝SL03开启预售,以及长安蓝鲸plus新车报价对...
比亚迪f3汽车报价(比亚迪f3... 今天给各位分享比亚迪f3汽车报价的知识,其中也会对比亚迪f3价格及图片易车进行解释,如果能碰巧解决你...
两台电脑怎么共享一台打印机,两... 两台电脑怎么共享一台打印机目录两台电脑怎么共享一台打印机两台电脑如何共享一台打印机?请问一个打印机怎...
16个复韵母有哪些(16个复韵... 本篇文章极速百科给大家谈谈16个复韵母有哪些,以及16个复韵母怎么读拼音视频对应的知识点,希望对各位...
樟树有什么作用,樟树有什么作用... 樟树有什么作用目录樟树有什么作用樟树有什么作用?樟树的用途有哪些?樟树有什么作用?樟树有什么作用 ...
dazl启动子的作用,启动子和... dazl启动子的作用目录dazl启动子的作用启动子和终止子是什么作用的?dazl启动子的作用启动子的...
写字楼是干什么的 极速百科网 ... 写字楼是干什么的目录写字楼是干什么的写字楼是干什么的写字楼是干什么的 写字楼的功能介绍写字楼是干什么...
骄傲的两种解释,骄傲的意思是什... 骄傲的两种解释目录骄傲的两种解释骄傲的意思是什么?骄傲的两种解释骄傲的两种解释 “骄傲”有两个...
jp是哪个国家的缩写(jp是哪... 本篇文章极速百科给大家谈谈jp是哪个国家的缩写,以及jp是哪个国家的缩写名字对应的知识点,希望对各位...
苹果手机显示不支持此配件怎么办... 不支持此配件怎么解决 苹果iphone可能不支持此配件怎么办怎么解除不支持此配件 不支持此配件怎么解...
支付宝借呗的利息是多少,蚂蚁借... 支付宝借呗的利息是多少目录支付宝借呗的利息是多少蚂蚁借呗利息是怎么计算的蚂蚁借呗的利息是多少借呗的利...
关于兰字的词语或成语越多越好.... 关于兰字的词语或成语越多越好.目录关于兰字的词语或成语越多越好.有关兰字的成语有哪些关于兰的词语或成...
宝马m5多少钱是不是很贵呢?(... 本篇文章极速百科给大家谈谈宝马m5多少钱是不是很贵呢?,以及宝马m5li多少钱对应的知识点,希望对各...
辽宁省喀左县在哪个城市,辽宁省... 辽宁省喀左县在哪个城市目录辽宁省喀左县在哪个城市辽宁省朝阳市喀左县的邮政编码辽宁省喀左县在哪里辽宁省...
关于marcjacobs香水,... 关于marcjacobs香水目录关于marcjacobs香水marcjacobs香水(探索时尚与艺术...
四级英语考试时间分配,大学英语... 四级英语考试时间分配目录四级英语考试时间分配大学英语四级考多长时间?英语四级考试时间安排?英语四级考...
dnfbuff强化有什么用,地... dnfbuff强化有什么用目录dnfbuff强化有什么用地下城buff强化栏DNF中人物的Buff有...
幼儿园孩子新年祝福语简短,适合... 幼儿园孩子新年祝福语简短目录幼儿园孩子新年祝福语简短适合幼儿园小朋友说的新年祝福语幼儿园老师给小朋友...
正断层有哪些断层组合类型,断层... 正断层有哪些断层组合类型目录正断层有哪些断层组合类型断层的组合类型简答题 断层的类型及组合形式有哪些...