1. 在struts-config.xml裏,以插件的形式
這種方式如果沒有配置contextConfigLocation的值,則會自動加載xx-servlet.xml.
xx的值是和web.xml裏的配置org.apache.struts.action.ActionServlet的servlet-name的值一樣
如下:xx的值也就是 action,所以會自動加載action-servlet.xml
如果sturts-config.xml裏配置了contextConfigLocation的值,那麼就不會自動加載xx-servlet.xml了,而只會加載contextConfigLocation所指定的xml.
2. 第2種方式
在web.xml裏配置Listener
如果在web.xml裏給該Listener指定要加載的xml,如:
則會去加載相應的xml,而不會去加載/WEB-INF/下的applicationContext.xml。。但是,如果沒有指定的話,默認會去/WEB-INF/下加載applicationContext.xml。
3. 第三種方式:ContextLoaderServlet
這種方式和第二種Listener方式一樣,唯一的區別就是用Listener方式初始化ApplicationContext,可以和用第一種方式(struts-config.xml裏 plugin方式)同時存在,而ContextLoaderServlet則不可以和第一種方式同時存在
總結:
ContextLoaderServlet已經不推薦用了,它只是爲了兼容低版本的servlet.jar才用的。
總的來說:Listerner要比Servlet更好一些,而且Listerner監聽應用的啓動和結束,而Servlet啓動要稍微延遲一些。
spring爲ApplicationContext提供的3種實現分別爲:ClassPathXmlApplicationContext,FileSystemXmlApplicationContext和XmlWebApplicationContext,其中XmlWebApplicationContext是專爲Web工程定製的。使用舉例如下:
1. FileSystemXmlApplicationContext
eg1. ApplicationContext ctx = new FileSystemXmlApplicationContext("bean.xml"); //加載單個配置文件
eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new FileSystemXmlApplicationContext(locations ); //加載單個配置文件
eg3.
ApplicationContext ctx =new FileSystemXmlApplicationContext("D:/project/bean.xml");//根據具體路徑加載文件
2. ClassPathXmlApplicationContext
eg1. ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml");
eg2.
String[] locations = {"bean1.xml", "bean2.xml", "bean3.xml"};
ApplicationContext ctx = new ClassPathXmlApplication(locations);
注:其中FileSystemXmlApplicationContext和ClassPathXmlApplicationContext與BeanFactory的xml文件定位方式一樣是基於路徑的。
3. XmlWebApplicationContext
eg1. ServletContext servletContext = request.getSession().getServletContext();
ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(servletContext);