一 整个项目的框架,文件夹分布
二 一些重要的配置文件
2.1 struts.xml
此配置文件主要申明了
<!-- 使用spring的工厂去替换struts2的默认工厂,也就是Action由spring来创建和维护 -->
<constant name="struts.objectFactory" value="spring" />
然后引入一些
<include file="cn/citic/trade/login/loginStruts.xml"></include>
具体的struts配置还是利用上面的引入,分布到具体的模块去些,这里只是一个集合,方便管理。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <include file="struts-default.xml" /> <!-- 指定Web应用的默认编码集,相当于调用HttpServletRequest的setCharacterEncoding方法 --> <constant name="struts.i18n.encoding" value="UTF-8" /> <constant name="struts.action.extension" value="action" /> <!-- 设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭 --> <constant name="struts.serve.static.browserCache" value="false" /> <!-- 当struts的配置文件修改后,系统是否自动重新加载该文件,默认值为false(生产环境下使用),开发阶段最好打开 --> <constant name="struts.configuration.xml.reload" value="true" /> <!-- 开发模式下使用,这样可以打印出更详细的错误信息 --> <constant name="struts.devMode" value="false" /> <!-- 默认的视图主题 --> <constant name="struts.ui.theme" value="simple" /> <!-- 文件上传时的临时目录 --> <constant name="struts.multipart.saveDir" value="D:/temp" /> <constant name="struts.multipart.maxSize" value="204800000" /> <!-- 使用spring的工厂去替换struts2的默认工厂,也就是Action由spring来创建和维护 --> <constant name="struts.objectFactory" value="spring" /> <package name="main" namespace="/" extends="json-default"> <interceptors> <interceptor name="sessionTimeOut" class="cn.citic.trade.interceptor.SessionInterceptor" /> <interceptor name="trimInterceptor" class="cn.citic.trade.interceptor.TrimInterceptor" /> <!-- Session权限拦截器栈 --> <interceptor-stack name="sessionTimeOutStack"> <!-- 去参数前后空格 --> <interceptor-ref name="trimInterceptor" /> <!-- 使用系统默认的拦截器 --> <interceptor-ref name="defaultStack" /> <!-- 使用自定义的拦截器 --> <interceptor-ref name="sessionTimeOut" /> </interceptor-stack> </interceptors> </package> <!-- 引用功能模块对应的Strusw配置文件 --> <include file="cn/citic/trade/login/loginStruts.xml"></include> <include file="cn/citic/trade/merchant/merchantStruts.xml"></include> <include file="cn/citic/trade/user/userStruts.xml"></include> <include file="cn/citic/trade/trade/tradeStruts.xml"></include> <include file="cn/citic/trade/report/reportStruts.xml"></include> <include file="cn/citic/trade/permission/permissionStruts.xml"></include> <include file="cn/citic/trade/credit/creditStruts.xml"></include> <!-- 二期需求 --> <include file="cn/citic/trade/aerra/aerraStruts.xml"></include> <include file="cn/citic/trade/tradetype/tradeTypeStruts.xml"></include> </struts>
2.2 某个模块的struts配置文件,xxxStruts.xml
在这个配置文件,主要申明了某个模块用哪个Action类来控制和这个控制类处理之后的页面跳转结果页面。由于是利用Spring来管理struts,配置文件里写的处理类名字,其实是在Spring的bean配置文件里面申明好的一个id名字
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <package name="aerra" namespace="/" extends="main"> <!-- xxxx交易流水功能管理 --> <action name="aerra_*" class="aerraTradeAction" method="{1}"> <!-- 登录超时和Session权限的拦截器栈 --> <interceptor-ref name="sessionTimeOutStack" /> <result name="timeout">/timeout.jsp</result> <result name="uploadSuccess">/WEB-INF/aerra/aerra_upload_messages.jsp</result> <result name="uploadError">/WEB-INF/aerra/aerra_upload_messages.jsp</result> <result name="list">/WEB-INF/report/bank_fee_income_list.jsp</result> <result name="addUI">/WEB-INF/report/bank_fee_income_add.jsp</result> <result name="editUI">/WEB-INF/report/bank_fee_income_edit.jsp</result> <result name="success">/WEB-INF/report/ajaxDone.jsp</result> <result name="error">/WEB-INF/report/ajaxDone.jsp</result> </action> </package> </struts>
其中的<package name="aerra" namespace="/" extends="main">里面的name="aerra"是模块名, namespace="/"反映在url上就是模块名之前的路径 触发的时候是url/aerra 这样
而<action name="aerra_*" class="aerraTradeAction" method="{1}">的 name="aerra_*" 是指只要请求的地址里模块是以aerra_开头的,就进入class="aerraTradeAction"这个类来处理,而这个 erraTradeAction 是由spring管理的,在spring的bean配置文件面进行申明。
2.3 applicationContext.xml
这个配置文件配置了c3p0连接池,注入hibernate的mapping映射文件,注入了各个模块对应的SpringBean配置文件(里面申明了Aciton类和操作数据库接口实现类),还有申明了会话工厂sessionFactory,在接口实现类里面直接用sessionFactory就可以操作数据库相关,比如实例化连接池然后操作数据库之类。
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <context:annotation-config /> <!-- C3p0数据源 ,做成了单例模式 --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass" value="net.sourceforge.jtds.jdbc.Driver" /> <property name="jdbcUrl" value="jdbc:jtds:sqlserver://localhost:1433/citic" /> <property name="user" value="sa" /> <property name="password" value="xxxxxx" /> <!-- 每60秒检查所有连接池中的空闲连接。Default:0 --> <property name="idleConnectionTestPeriod" value="60" /> <!-- 初始化时获取的链接数,取值应在minPoolSize与maxPoolSize之间。Default:3 --> <property name="initialPoolSize" value="2" /> <!-- 连接池中保留的最小连接数 --> <property name="minPoolSize" value="1" /> <!-- 连接池中保留的最大连接数。Default:15 --> <property name="maxPoolSize" value="20" /> <!-- 最大空闲时间,120秒内未使用则连接被丢弃。右为0则永不丢弃。Default:0 --> <property name="maxIdleTime" value="120" /> <!-- 当连接池中的连接耗尽时,c3p0一次同时获取的连接数。Default:3 --> <property name="acquireIncrement" value="5" /> </bean> <!-- 会话工厂 --> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <!-- 注入数据源 --> <property name="dataSource" ref="dataSource" /> <!-- 指定 Hibernate 的映射文件 --> <property name="mappingResources"> <list> <!-- 交易类型表:二期需求 --> <value>cn/citic/trade/tradetype/bean/TradeType.hbm.xml</value> <!-- 用户信息表 --> <value>cn/citic/trade/user/bean/UserInfo.hbm.xml</value> <value>cn/citic/trade/merchant/bean/BigMerchantInfo.hbm.xml</value> <value>cn/citic/trade/merchant/bean/SmallMerchantInfo.hbm.xml</value> <value>cn/citic/trade/trade/bean/MerchantTradeInfoTemp.hbm.xml</value> <value>cn/citic/trade/trade/bean/SecondCountInfo.hbm.xml</value> <value>cn/citic/trade/credit/bean/CreditSummonsInfo.hbm.xml</value> <value>cn/citic/trade/merchant/bean/MccMainbiz.hbm.xml</value> <value>cn/citic/trade/trade/bean/MerchantSummaryByMonths.hbm.xml</value> <!-- 权限模块 --> <value>cn/citic/trade/permission/bean/PermissionOperate.hbm.xml</value> <value>cn/citic/trade/permission/bean/PermissionRole.hbm.xml</value> <value>cn/citic/trade/permission/bean/PermissionGroup.hbm.xml</value> <value>cn/citic/trade/permission/bean/PermiessionGroupRole.hbm.xml</value> <value>cn/citic/trade/permission/bean/PermissionRoleOperate.hbm.xml</value> <value>cn/citic/trade/report/bean/BankIncomeAccount.hbm.xml</value> <value>cn/citic/trade/report/bean/BankFeeIncome.hbm.xml</value> <value>cn/citic/trade/aerra/bean/AerraTradeInfo.hbm.xml</value> </list> </property> <!-- 设置Hibernate属性 --> <property name="hibernateProperties"> <value> hibernate.dialect=org.hibernate.dialect.SQLServerDialect hibernate.hbm2ddl.auto=update hibernate.show_sql=false hibernate.format_sql=false </value> </property> </bean> <!-- 配置关于Hibernate的事务管理器,以使用Spring提供的事务管理功能 --> <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <!-- 使用基于注解方式来配置事务 --> <tx:annotation-driven transaction-manager="txManager" /> <!-- 用于注入分页用到的PageDaoImpl实例--> <bean id="pageDao" class="cn.citic.trade.utils.page.PageDaoImpl"> <property name="sessionFactory" ref="sessionFactory"></property> </bean> <!-- 导入各部份功能对应的applicationContext文件 --> <import resource="cn/citic/trade/login/loginBeans.xml" /> <import resource="cn/citic/trade/merchant/merchantBeans.xml" /> <import resource="cn/citic/trade/user/userBeans.xml" /> <import resource="cn/citic/trade/trade/tradeBeans.xml" /> <import resource="cn/citic/trade/report/reportBeans.xml" /> <import resource="cn/citic/trade/permission/permissionBeans.xml" /> <import resource="cn/citic/trade/credit/creditBeans.xml" /> <!-- 二期需求:交易类型码 --> <import resource="cn/citic/trade/tradetype/tradeTypeBeans.xml" /> <import resource="cn/citic/trade/aerra/aerraBeans.xml" /> </beans>
2.4 某个模块的springBean配置文件
这里配置的是这个模块的action申明 接口实现类申明 然后用spring进行注入,以后直接调用配置文件里面的id名字,就可以实现这些类,也不用自己申明,服务器在启动的时候,已经找到这些配置文件进行实例化了,注入就可以使用
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <!--service bean --> <!-- 机构差错交易流水功能管理接口 --> <bean id="aerraTradeService" class="cn.citic.trade.aerra.service.impl.AerraTradeServiceBean" /> <!--action bean --> <!-- 机构差错交易流水功能Action --> <bean id="aerraTradeAction" class="cn.citic.trade.aerra.action.AerraTradeAction" scope="prototype" /> </beans>
2.5 log4j.properties配置文件
加入log4j的lib之后,通过这个配置文件,就可以使用log4j来打印log了。只需要在程序里这样:
private static final Log log = LogFactory.getLog(AerraTradeAction.class);
log.warn()
or
log.info()
就可以使用了
# Logger - 日志写出器,供程序员输出日志信息 #log4j.rootLogger=DEBUG,CONSOLE,FILE,ROLLING_FILE,DATABASE,MAIL log4j.rootLogger=INFO,CONSOLE,DRF 这里配置打印类型,加上info 就可以打印log.info的信息了,没加的不显示 #log4j.rootLogger=ERROR,CONSOLE #log4j.rootLogger=WARN,CONSOLE,FILE,ROLLING_FILE,DATABASE,MAIL #log4j.rootLogger=ERROR,CONSOLE,FILE,ROLLING_FILE,DATABASE,MAIL #log4j.rootLogger=FATAL,CONSOLE,FILE,ROLLING_FILE,DATABASE,MAIL # CONSOLE # ConsoleAppender - 目的地为控制台的Appender log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.Threshold=DEBUG log4j.appender.CONSOLE.Target=System.out # Layout - 日志格式化器,用来把程序员的logging request格式化成字符串 # PatternLayout - 用指定的pattern格式化logging request的Layout log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout #log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p]-[%d{yyyy-MM-dd HH:mm:ss,SSS}]-[%c.java:%L] %m%n log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n #应用于文件 # FileAppender - 目的地为文件的Appender log4j.appender.FILE=org.apache.log4j.FileAppender log4j.appender.FILE.File=${catalina.home}/logs/CiticTradeFile.log log4j.appender.FILE.Append=false log4j.appender.FILE.layout=org.apache.log4j.PatternLayout #log4j.appender.FILE.layout.ConversionPattern=[%-5p]-[%d{yyyy-MM-dd HH:mm:ss,SSS}]-[%c.java:%L] %m%n log4j.appender.FILE.layout.ConversionPattern=[%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n # 应用于文件回滚 # RollingFileAppender - 目的地为大小受限的文件的Appender log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender log4j.appender.ROLLING_FILE.Threshold=ERROR log4j.appender.ROLLING_FILE.File=${catalina.home}/logs/rolling.log # 文件最大尺寸 log4j.appender.ROLLING_FILE.MaxFileSize=1024KB # 备份数 log4j.appender.ROLLING_FILE.MaxBackupIndex=1 log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout log4j.appender.ROLLING_FILE.layout.ConversionPattern=[%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n # DailyRollingFileAppender(每天产生一个日志文件) log4j.appender.DRF=org.apache.log4j.DailyRollingFileAppender log4j.appender.DRF.Threshold=WARN log4j.appender.DRF.DatePattern='.'yyyy-MM-dd log4j.appender.DRF.File=${catalina.home}/logs/CiticTradeDRF.log log4j.appender.DRF.Append=true log4j.appender.DRF.layout=org.apache.log4j.PatternLayout log4j.appender.DRF.layout.ConversionPattern=[%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n #应用于数据库 log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender log4j.appender.DATABASE.Threshold=FATAL log4j.appender.DATABASE.URL=jdbc:microsoft:sqlserver://xxxxx;DatabaseName=citic log4j.appender.DATABASE.driver=com.microsoft.jdbc.sqlserver.SQLServerDriver log4j.appender.DATABASE.user=sa log4j.appender.DATABASE.password=xxxxx log4j.appender.DATABASE.sql=INSERT INTO TRADE_MY_LOG (USER_NO,USER_NAME,LOG_DATE,LOG_TIME,LOG_CLASS,LOG_METHOD,LOG_LEVEL,LOG_CONTENT,REMARK) VALUES ('%X{MDC_USER_NO}','%X{MDC_USER_NAME}','%d{yyyy-MM-dd HH:mm:ss,SSS}','%d{yyyy-MM-dd HH:mm:ss,SSS}','%c.java:%L','%M','%p','%m%n','') log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout log4j.appender.DATABASE.layout.ConversionPattern=[%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n
在Action里面使用其他接口或其他类,也很简单,直接注入就可以
@Resource
private AerraTradeService aerraTradeService;
然后可以直接用那个对象,来调用方法使用了