applicationContext.xml

hibernate.cfg.xml

 
org.hibernate.dialect.MySQL5InnoDBDialect
true

jdbc.properties

    jdbcUrl = jdbc:mysql:///itcastoa0720

    driverClass         = com.mysql.jdbc.Driver

    user = root

    password         = root

    

log4j.properties

### direct log messages to stdout ###

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.stdout.Target=System.out

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### direct messages to file hibernate.log ###

#log4j.appender.file=org.apache.log4j.FileAppender

#log4j.appender.file.File=hibernate.log

#log4j.appender.file.layout=org.apache.log4j.PatternLayout

#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### set log levels - for more verbose logging change 'info' to 'debug' ###

log4j.rootLogger=warn, stdout

#log4j.logger.org.hibernate=info

#log4j.logger.org.hibernate=debug

log4j.logger.cn.itcast.oa=debug

struts.xml

    
    
    
    
    
    
    
    
    
         
    
    
    
         
/WEB-INF/jsp/userAction/loginUI.jsp
/noPrivilegeError.jsp
    
/test.jsp
/WEB-INF/jsp/roleAction/list.jsp
/WEB-INF/jsp/roleAction/saveUI.jsp
/WEB-INF/jsp/roleAction/setPrivilegeUI.jsp
role_list
/WEB-INF/jsp/departmentAction/list.jsp
/WEB-INF/jsp/departmentAction/saveUI.jsp
department_list?parentId=${parentId}
/WEB-INF/jsp/userAction/list.jsp
/WEB-INF/jsp/userAction/saveUI.jsp
user_list
/WEB-INF/jsp/userAction/logout.jsp
/index.jsp
/WEB-INF/jsp/homeAction/{1}.jsp
/WEB-INF/jsp/forumManageAction/list.jsp
/WEB-INF/jsp/forumManageAction/saveUI.jsp
forumManage_list
/WEB-INF/jsp/forumAction/list.jsp
/WEB-INF/jsp/forumAction/show.jsp
/WEB-INF/jsp/topicAction/show.jsp
/WEB-INF/jsp/topicAction/addUI.jsp
topic_show?id=${id}
/WEB-INF/jsp/replyAction/addUI.jsp
topic_show?id=${topicId}         

web.xml

org.springframework.web.context.ContextLoaderListener
contextConfigLocation
classpath:applicationContext*.xml
cn.itcast.oa.util.InitListener
OpenSessionInViewFilter
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
OpenSessionInViewFilter
*.action
struts2
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
struts2
/*
index.jsp

    Spring为我们解决最让人头痛的难题之一,Hibernate的Session的关闭与开启问题。 Hibernate 允许对关联对象、属性进行延迟加载,但是必须保证延迟加载的操作限于同一个 Hibernate Session 范围之内进行。如果 Service 层返回一个启用了延迟加载功能的领域对象给 Web 层,当 Web 层访问到那些需要延迟加载的数据时,由于加载领域对象的 Hibernate Session 已经关闭,这些导致延迟加载数据的访问异常。而Spring为我们提供的OpenSessionInViewFilter过滤器为我们很好的解决了这个问题。OpenSessionInViewFilter的主要功能是使每个请求过程绑定一个 Hibernate Session,即使最初的事务已经完成了,也可以在 Web 层进行延迟加载的操作。OpenSessionInViewFilter 过滤器将 Hibernate Session 绑定到请求线程中,它将自动被 Spring 的事务管理器探测到。所以 OpenSessionInViewFilter 适用于 Service 层使用HibernateTransactionMana<wbr>ger 或 JtaTransactionManager 进行事务管理的环境,也可以用于非事务只读的数据操作中