一.Struts2的工作流程:
1.用戶在客戶端發起請求,客戶端會初始化一個servlet容器請求;
2.servlet容器把請求會傳遞給context容器,context容器找到目標web工程。
3.進行解析web.xml中的struts標簽中的配置:
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-
class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
4.然后進行struts的一系列的過濾器,如:ActionContextClearUp;
5.接着FilterDispatcher會被調用,它在轉發到某個Actio之前,要先詢問
ActionMapper(它會判斷是否有Action要被執行);
6.如果有,FilterDispatch會將請求交給我們的ActionProxy(Action代理);
7.然后ActionProxy會通過Configure Manager詢問框架的具體配置,找到action配置信息,在通過ActionInnvcation
實例Action對象;
8.執行Action對象的方法,返回結果;
9.根據返回結果在struts.xml中Action子標簽result跳轉具體的處理頁面或另一個Action;
10.響應給我們的用戶。
二.Hibernate的工作流程:
1.當我們使用myeclipse加入hibernate組件時,這個組件會為我們自動生成HibernateSessionFactory類和
hibernate.cfg.xml文件;
2.在hibernate.cfg.xml中主要進行了sessionFatory的配置,它包括數據庫的連接信息,還有緩存信息;
<session-factory>
<property name="dialect">
org.hibernate.dialect.Oracle9Dialect
</property>
<property name="connection.url">
jdbc:oracle:thin:@127.0.0.1:1521:orcl
</property>
<property name="connection.username">system</property>
<property name="connection.password">java</property>
<property name="connection.driver_class">
oracle.jdbc.driver.OracleDriver
</property>
<property name="myeclipse.connection.profile">oeconn</property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<property name="cache.provider_class">
org.hibernate.cache.EhCacheProvider
</property>
</session-factory>
3.有誰來讀取和解析這么重要的配置文件呢? 當然是HibernateSessionFactory了。
在這個類中有一段靜態代碼塊:
private static final ThreadLocal<Session> threadLocal = new ThreadLocal<Session>();
private static org.hibernate.SessionFactory sessionFactory;
private static Configuration configuration = new Configuration();
private static ServiceRegistry serviceRegistry;
static {
try {
configuration.configure();
serviceRegistry = new ServiceRegistryBuilder().applySettings
(configuration.getProperties()).buildServiceRegistry();
sessionFactory = configuration.buildSessionFactory(serviceRegistry);
} catch (Exception e) {
System.err.println("%%%% Error Creating SessionFactory %%%%");
e.printStackTrace();
}
}
在這個靜態代碼塊中:通過Configuration類的configure方法加載解析hibernate.cfg.xml;同時也創建了
sessionFactory對象(它用來創建session對象的),所以在tomcat服務器啟動時就會運行該段代碼;
在這里順便提提session創建過程:
1)為什么session要放在ThreadLocal<Session> 中?
我們的模板類雖然是通過資源池獲取數據庫連接或會話對象的,根據持久化技術的不同,模板類需要
綁定數據庫連接和會話資源,但這些資源本身是非線程安全的,也就是不能被多個線程共享,所以它
Hibernate不需同步就可以解決線程安全問題,所以它將session放在了ThreadLocal中。
2)通過SessionFatory創建一個單例session
public static Session getSession() throws HibernateException {
Session session = (Session) threadLocal.get();
if (session == null || !session.isOpen()) {
if (sessionFactory == null) {
rebuildSessionFactory();
}
session = (sessionFactory != null) ? sessionFactory.openSession()
: null;
threadLocal.set(session);
}
return session;
}
4.創建事務對象session.BeginTransaction方法
5.創建持久化對象session.createQuery方法
6.提交事務
7.關閉session、sessionFactory.
三.Spring的工作流程:
1.在myeclipse中加入Spring組件,產生一個applicationContext.xml文件。
2.在web.xml中加入以下配置:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
web工程進入到web.xml中掃描,發現有ContextLoaderListener類,監聽器,那就說明有Spring組件了。
在找發現<context-param>標簽中有classpath值,然后流程轉到applicationContext.xml中去;
在beans標簽下會加入數據源信息(數據庫的配置信息)。
<!-- 加入數據源 -->
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="oracle.jdbc.driver.OracleDriver">
</property>
<property name="url"
value="jdbc:oracle:thin:@localhost:1521:orcl">
</property>
<property name="username" value="empdb"></property>
<property name="password" value="java"></property>
</bean>
3.然后通過Ioc控制反轉注入bean。實現了對象不用自己new
,Spring會幫你完成,交給他托管。
<!-- 注入JdbcTemplate類 -->
<bean id="jdbctemp" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 注入dao類 -->
<bean id="bdao" class="com.dao.BankDao">
<property name="jtemp" ref="jdbctemp"></property>
</bean>
