1.init初始化webApplicationContext 然后加载xmlbeanFactory,加载各种xml,
2.按项目包的顺序从上到下依次初始化service和repository,跨包有依赖关系的先加载依赖的service,等加载到这个service的包后也不会再重复初始化这个service,如果没有配置的话接着初始化@Controller
3.然后初始化spring-core-config.xml中的bean标签的类,如:如果没有在别的类中使用@Autowired时在@controller和@Service之后调用,可以替换@service,在WebApplicationContext: initialization completed之前调用
4.如:org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:325) INFO - Root WebApplicationContext: initialization completed in 85329 ms,
5.最后加载spring dispatcherservlet namespace webApplicationContext ,即Refreshing WebApplicationContext for namespace 'spring-dispatcher-servlet': startup date [Sun Mar 29 11:22:18 CST 2020]; parent: Root WebApplicationContext,
6.按项目包的顺序从上到下依次初始化controller,
7.然后把requestmapping中的url绑定到对应的controller的方法上,例如以下
org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.registerHandlerMethod(AbstractHandlerMethodMapping.java:220) INFO - Mapped "{[/queryDetailRows],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public void com.xxx.xxx.xxx.controller.xxxController.queryDetailRows()
以下的xml配置就是去掉步骤2中初始化controller,让其只在初始化dispatcherservlet后初始化controller
applicationContext.xml的内容: