springmvc和springboot的一点不同在于springmvc依托tomcat启动。
tomcat是java原创团队写的,而现在的项目很多会调用自定义程序(非原创团队编写),包括一些注解,方法,甚至是controller。这些主方法所在的路径被记录在web.xml里面。
所以在项目启动的时候会扫描这个xml文件。
springmvc的一个启动原理首先扫描webapps,通过反射可以识别到的servlet文件,放入hashmap1中(基于tomcat)。
然后读取web.xml文件(启动第三方程序的入口),第三方程序开始扫描指定目录下的class文件,通过反射获取到所有类的信息,识别controller的注解并挑选出来。
然后通过反射获取到contrller的实例,还需要获取到所有方法的注解,挑选出前后端交互的方法,并且获取到方法的实例,存储到hashmap2中,key是requestmapping的注解路径--controller类注解+方法注解,value:是controller实例+方法实例。
如何拿到数据并进行方法的执行的通过监听端口,获得解析http协议,拿到路径和数据,匹配hashmap1的路径找到对应的servlet。
接下来看一段配置源码
Archetype Created Web Application dispatcher org.springframework.web.servlet.DispatcherServlet contextConfigLocation classpath:springContext.xml 1 dispatcher / contextConfigLocation classpath:springContext.xml org.springframework.web.context.ContextLoaderListener
所有的mapping都被归入到一个叫dispatcher的servlet,可以得到请求路径,然后去和hashmap2中匹配对应的controller实例和方法实例,最后通过invoke调用。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)