struts2.3.1.1+hibernate3.6.9Final+spring3.1.0+proxool+maven+annotation
==============POM.XML==============
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0 " xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance "
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd ">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tcs.org.demostic</groupId>
<artifactId>mydemo</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>mydemo Maven Webapp</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<finalName>mydemo</finalName>
</properties>
<repositories>
<repository>
<id>MavenCentral</id>
<name>Maven repository</name>
<url>http://repo1.maven.org/maven2</url>
</repository>
<repository>
<id>Codehaus Snapshots</id>
<url>http://snapshots.repository.codehaus.org/</url>
</repository>
<repository>
<id>ibiblio</id>
<url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
</repository>
<repository>
<id>datanucleus</id>
<url>http://www.datanucleus.org/downloads/maven2/</url>
</repository>
<repository>
<id>gwt-maven</id>
<url>http://gwt-maven.googlecode.com/svn/trunk/mavenrepo/</url>
</repository>
<repository>
<id>maven2-repository.dev.java.net</id>
<url>http://download.java.net/maven/2/</url>
</repository>
<repository>
<id>jboss</id>
<url>http://repository.jboss.com/maven2</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>apache.snapshots</id>
<name>Apache Snapshot Repository</name>
<url>http://people.apache.org/repo/m2-snapshot-repository</url>
<releases>
<enabled>false</enabled>
</releases>
</pluginRepository>
<pluginRepository>
<id>Codehaus Snapshots</id>
<url>http://snapshots.repository.codehaus.org/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>false</enabled>
</releases>
</pluginRepository>
<pluginRepository>
<id>MavenCentral</id>
<name>Maven repository</name>
<url>http://repo1.maven.org/maven2</url>
</pluginRepository>
<pluginRepository>
<id>ibiblio</id>
<url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
</pluginRepository>
<pluginRepository>
<id>datanucleus</id>
<url>http://www.datanucleus.org/downloads/maven2/</url>
</pluginRepository>
<pluginRepository>
<id>gwt-maven</id>
<url>http://gwt-maven.googlecode.com/svn/trunk/mavenrepo/</url>
</pluginRepository>
<pluginRepository>
<id>maven2-repository.dev.java.net</id>
<url>http://download.java.net/maven/2/</url>
</pluginRepository>
<pluginRepository>
<id>jboss</id>
<url>http://repository.jboss.com/maven2</url>
</pluginRepository>
</pluginRepositories>
<dependencies>
<!--============J2EE容器所需包===============-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.9</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>aopalliance</groupId>
<artifactId>aopalliance</artifactId>
<version>1.0</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.6.12</version>
</dependency>
<!--=============commons===================-->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.1</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.2.2</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>commons-chain</groupId>
<artifactId>commons-chain</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>commons-digester</groupId>
<artifactId>commons-digester</artifactId>
<version>2.1</version>
</dependency>
<dependency>
<groupId>commons-validator</groupId>
<artifactId>commons-validator</artifactId>
<version>1.4.0</version>
</dependency>
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
<version>2.6</version>
</dependency>
<!-- 集合类 -->
<dependency>
<groupId>commons-collections</groupId>
<artifactId>commons-collections</artifactId>
<version>3.2.1</version>
</dependency>
<!--===============dom4j====================-->
<!-- XML配置和映射管理器-->
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>net.sf.json-lib</groupId>
<artifactId>json-lib</artifactId>
<version>2.4</version>
<classifier>jdk15</classifier>
</dependency>
<!--==============字节码库=====================-->
<!-- ASM字节码库 -->
<dependency>
<groupId>asm</groupId>
<artifactId>asm</artifactId>
<version>3.1</version>
</dependency>
<!-- ASM字节码库-->
<dependency>
<groupId>asm</groupId>
<artifactId>asm-attrs</artifactId>
<version>2.2.3</version>
</dependency>
<dependency>
<groupId>asm</groupId>
<artifactId>asm-commons</artifactId>
<version>3.3.1</version>
</dependency>
<!--===================SpringDM Bundle================-->
<dependency>
<groupId>org.springframework.osgi</groupId>
<artifactId>spring-osgi-core</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>org.springframework.osgi</groupId>
<artifactId>spring-osgi-mock</artifactId>
<version>1.1.3</version>
</dependency>
<!--===================Felix Bundle================-->
<!--===================spring3.1.0.RELEASE================-->
<dependency>
<groupId>quartz</groupId>
<artifactId>quartz</artifactId>
<version>1.5.1</version>
</dependency>
<!-- spring必须包 -->
<!-- spring核心包 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>3.1.0.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>3.1.0.RELEASE</version>
<!-- spring-asm-3.1.0.RELEASE.jar -->
<!-- commons-logging-1.1.1.jar -->
</dependency>
<!-- 利用IOC管理Bean的包 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>3.1.0.RELEASE</version>
</dependency>
<!-- 对bean再次封装后的包,方便性强。 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.1.0.RELEASE</version>
<!-- spring-expression-3.1.0.RELEASE.jar -->
<!-- spring-aop-3.1.0.RELEASE.jar -->
<!-- aopalliance-1.0.jar -->
</dependency>
<!-- spring扩展包 -->
<!-- SpringWeb下的工具包 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.1.0.RELEASE</version>
</dependency>
<!-- 支持hibernate,对对象映射框架的支持 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>3.1.0.RELEASE</version>
<!-- spring-tx-3.1.0.RELEASE.jar -->
<!-- spring-jdbc-3.1.0.RELEASE.jar -->
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>3.1.0.RELEASE</version>
<!-- spring-tx-3.1.0.RELEASE.jar -->
<!-- spring-jdbc-3.1.0.RELEASE.jar -->
</dependency>
<!--================struts2.3.1.1=================-->
<!-- struts2.3.1.1必须包 --><dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-core</artifactId>
<version>2.3.1.1</version>
<!-- ognl-3.0.3.jar -->
<!-- asm-commons-3.1.jar -->
<!-- asm-tree-3.1.jar -->
<!-- commons-lang-2.5.jar -->
<!-- commons-fileupload-1.2.2.jar -->
<!-- commons-io-2.0.1.jar -->
<!-- xwork-core-2.3.1.1.jar -->
<!-- javassist-3.11.0.GA.jar -->
<!-- freemarker-2.3.18.jar -->
</dependency>
<!-- struts2对于spring的支持 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-spring-plugin</artifactId>
<version>2.3.1.1</version>
</dependency>
<!-- struts2对于json的支持 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-json-plugin</artifactId>
<version>2.3.1.1</version>
</dependency>
<!-- struts2对于spring的支持 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-jfreechart-plugin</artifactId>
<version>2.3.1.1</version>
</dependency>
<!-- struts2中对于注解的支持 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-convention-plugin</artifactId>
<version>2.3.1.1</version>
</dependency>
<!--==================hibernate3.6.9.Final===================-->
<!-- hibernate3.6.9必须包 -->
<!-- hibernate核心包 -->
<dependency>
<groupId>antlr</groupId>
<artifactId>antlr</artifactId>
<version>2.7.7</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>3.6.9.Final</version>
</dependency>
<!-- hibernate使用的一个日志系统 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.16</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.6.4</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.4</version>
</dependency>
<!-- ==============mysql数据库驱动 ===================-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.18</version>
</dependency>
<dependency>
<groupId>oracle</groupId>
<artifactId>ojdbc14_g</artifactId>
<version>10.2.0.4</version>
</dependency>
<!-- ==============dbcp数据库连接池 ===================-->
<!--
<dependency> <groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId> <version>1.4</version>
</dependency>
-->
<!-- cglib字节码解释器-->
<!--
<dependency> <groupId>cglib</groupId>
<artifactId>cglib-nodep</artifactId> <version>2.2.2</version>
</dependency>
-->
<!-- ==============c3p0数据库连接池 ===================-->
<!--
<dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId>
<version>0.9.1.2</version> </dependency>
-->
<!-- ==============proxool数据库连接池===================-->
<dependency>
<groupId>proxool</groupId>
<artifactId>proxool</artifactId>
<version>0.9.0RC3</version>
</dependency>
<!-- ==============解决jar包冲突问题===================-->
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-embedder</artifactId>
<version>2.0</version>
<exclusions>
<exclusion>
<groupId>org.apache.maven</groupId>
<artifactId>maven-core</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<!-- ==============解决build打包问题===================-->
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat6-maven-plugin</artifactId>
<version>2.0-SNAPSHOT</version>
</plugin>
</plugins>
</pluginManagement>
<finalName>mydemo</finalName>
<sourceDirectory>src/main/java</sourceDirectory>
<outputDirectory>src/main/webapp/WEB-INF/classes</outputDirectory>
<defaultGoal>install</defaultGoal>
<resources>
<resource>
<targetPath></targetPath>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>tomcat-maven-plugin</artifactId>
<version>1.1</version>
<configuration>
<url>http://localhost:8080/manager</url>
<server>myserver</server>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.0</version>
<extensions>false</extensions>
<inherited>true</inherited>
<configuration>
<classifier>test</classifier>
</configuration>
<dependencies></dependencies>
<executions></executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-eclipse-plugin</artifactId>
<version>2.6</version>
</plugin>
<plugin>
<!-- 设置javac编译器的版本和编码字符 -->
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.0.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<fork>false</fork>
<verbose>true</verbose>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<!--
<plugin> <groupId>org.mortbay.jetty</groupId>
<artifactId>maven-jetty-plugin</artifactId>
<version>6.1.24</version> </plugin
-->
<plugin>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<webappDirectory>target/mydemo/webapp
</webappDirectory>
<warSourceDirectory>src/main/webapp</warSourceDirectory>
</configuration>
</plugin>
<plugin>
<groupId>org.mortbay.jetty</groupId>
<artifactId>maven-jetty-plugin</artifactId>
<version>6.1.10</version>
<configuration>
<scanIntervalSeconds>10</scanIntervalSeconds>
<stopKey>foo</stopKey>
<stopPort>9999</stopPort>
</configuration>
<executions>
<execution>
<id>start-jetty</id>
<phase>pre-integration-test</phase>
<goals>
<goal>run</goal>
</goals>
<configuration>
<scanIntervalSeconds>0</scanIntervalSeconds>
<daemon>true</daemon>
</configuration>
</execution>
<execution>
<id>stop-jetty</id>
<phase>post-integration-test</phase>
<goals>
<goal>stop</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
</project>
==============================WEB.XML========
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee "
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance "
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd ">
<display-name>Archetype Created Web Application</display-name>
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>webapp.root</param-value>
</context-param>
<!-- log4j配置文件地址 -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>
<!-- 配置spring的配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/applicationContext.xml</param-value>
</context-param>
<!-- 配置proxool的配置文件 -->
<context-param>
<param-name>proxoolConfigLocation</param-name>
<param-value>/WEB-INF/classes/proxool.xml</param-value>
</context-param>
<!-- proxool监听 -->
<listener>
<listener-class>com.tcs.org.demostic.pub.until.ProxoolListener</listener-class>
</listener>
<!-- log4j监听 -->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<!-- Spring监听 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Spring 刷新Introspector防止内存泄露 -->
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>
<!-- Open Session In View Filter -->
<!--
Spring提供的一个针对Hibernate的一个支持类,
发起一个页面请求时打开Hibernate的Session,一直保持这个Session,直到这个请求结束
-->
<filter>
<filter-name>OpenSessionInViewFilter</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
<init-param>
<param-name>singleSession</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>OpenSessionInViewFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- spring编码过滤器 -->
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<!-- 强制进行转码 -->
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- Struts2配置信息 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
<!-- 指定配置文件路径 -->
<init-param>
<param-name>config</param-name>
<param-value>platform-web.xml,struts-default.xml,struts-plugin.xml,resources/struts/struts.xml</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- proxool提供的管理监控工具,可查看当前数据库连接情况。如果运行不成功,请删除本行 -->
<servlet>
<servlet-name>Admin</servlet-name>
<servlet-class>org.logicalcobwebs.proxool.admin.servlet.AdminServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Admin</servlet-name>
<url-pattern>/Admin</url-pattern>
</servlet-mapping>
<!--验证码servlet -->
<servlet>
<servlet-name>authImg</servlet-name>
<servlet-class>com.tcs.org.demostic.pub.until.AuthImg</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>authImg</servlet-name>
<url-pattern>/authImg</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>authFontImg</servlet-name>
<servlet-class>com.tcs.org.demostic.pub.until.AuthFontImg</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>authFontImg</servlet-name>
<url-pattern>/authFontImg</url-pattern>
</servlet-mapping>
<!-- 欢迎页面 -->
<welcome-file-list>
<welcome-file>login.jsp</welcome-file>
</welcome-file-list>
</web-app>
=====================APPLICATIONCONTEXT.XML===========
applicationContext.xml
<?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:jee="http://www.springframework.org/schema/jee "
xmlns:tx="http://www.springframework.org/schema/tx "
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.1.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd "
default-lazy-init="true">
<!-- aop 注解 -->
<aop:aspectj-autoproxy />
<!--
<bean class="org.springframework.aop.aspectj.annotation.AnnotationAwareAspectJAutoProxyCreator" />
-->
<!-- 使Spring关注Annotation -->
<context:annotation-config />
<!-- 让Spring通过自动扫描来查询和管理Bean-->
<context:component-scan base-package="com.tcs.org.demostic" />
<!--配置文件导入 -->
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
<value>/WEB-INF/classes/proxool.properties</value>
</property>
</bean>
<!--数据源 1 -->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName">
<value>org.logicalcobwebs.proxool.ProxoolDriver</value>
</property>
<property name="url">
<value>proxool.mydemo</value>
</property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<!-- 后台数据源配置连接池 开始 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${database.dialect}</prop>
<prop key="connection.provider_class">${database.connection}</prop>
<prop key="hibernate.proxool.xml">/WEB-INF/classes/proxool.xml</prop>
<prop key="hibernate.proxool.pool_alias">mydemo</prop>
<!-- 缓存设置默认是EhCache
<prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
<prop key="hibernate.cache.provider_configuration_file_resource_path">/WEB-INF/classes/ehcache-hibernate.xml</prop>
<prop key="jdbc.batch_size">20</prop>
<prop key="jdbc.fetch_size">20</prop>
<prop key="hibernate.cache.use_query_cache">true</prop>
<prop key="hibernate.cache.use_structured_entries">true</prop>
-->
<!--hibernate sql设置 -->
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.bytecode.use_reflection_optimizer">true</prop>
</props>
</property>
<!-- 前台数据源配置连接池 开始 -->
<!-- 前台数据源配置连接池 结束 -->
<!--主键Bean类开始-->
<property name="annotatedClasses">
<list>
<!-- pub start-->
<!-- pub Menu bean start -->
<!-- pub Menu bean over -->
<!-- pub over -->
<value>com.tcs.org.demostic.pub.security.group.bean.Group</value>
<value>com.tcs.org.demostic.pub.security.user.bean.User</value>
<value>com.tcs.org.demostic.pub.security.role.bean.Role</value>
<value>com.tcs.org.demostic.pub.security.auth.bean.Auth</value>
<value>com.tcs.org.demostic.pub.security.module.bean.Module</value>
<value>com.tcs.org.demostic.pub.security.menu.bean.Menu</value>
<value>com.tcs.org.demostic.pub.security.user.bean.UserDetail</value>
<value>com.tcs.org.demostic.pub.security.user.bean.UserSituation</value>
<!-- app start-->
<!-- public user bean start -->
<!-- public user bean over -->
<!-- app over -->
</list>
</property>
<!--主键Bean类结束-->
</bean>
<!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
<!-- 配置事务的传播特性 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="save*" propagation="REQUIRED" read-only="false"/>
<tx:method name="update*" propagation="REQUIRED" read-only="false"/>
<tx:method name="delete*" propagation="REQUIRED" read-only="false"/>
<tx:method name="*" read-only="true" />
</tx:attributes>
</tx:advice>
<!-- 那些类的哪些方法参与事务 -->
<aop:config>
<aop:pointcut id="allServiceMethod" expression="execution(* com.tcs.org.demostic.*.*.dao..*(..))" />
<aop:advisor pointcut-ref="allServiceMethod" advice-ref="txAdvice" />
</aop:config>
<!--
配置拦截器 <bean name="logginaop"
class="com.demo.pub.aops.login.LoggingInterceptor" />
-->
<!--
配置拦截器代理 <bean name="loggingAutoProxy"
class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
<property name="beanNames"> <list> <value>/loginon</value>
<value>/reg</value> </list> </property> <property
name="interceptorNames"> <list> <value>logginaop</value> </list>
</property> </bean>
-->
</beans>
=====================hibernate.cfg.xml====用处是生成表的作用==
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd ">
<!-- Generated by MyEclipse Hibernate Tools. 用不到整合到spring中去了 -->
<hibernate-configuration>
<session-factory>
<!-- mysql -->
<property name="connection.url">
jdbc:mysql://localhost:3306/mydemo?useUnicode=true&characterEncoding=utf-8
</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="connection.username">root</property>
<property name="connection.password">1</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<!-- oracle
<property name="connection.url">
jdbc:oracle:thin:@127.0.0.1:1521:demo
</property>
<property name="connection.driver_class">
oracle.jdbc.driver.OracleDriver
</property>
<property name="dialect">
org.hibernate.dialect.OracleDialect
</property>
<property name="connection.username">demo</property>
<property name="connection.password">1</property>
-->
<property name="connection.autocommit">true</property>
<property name="connection.useUnicode">true</property>
<property name="connection.characterEncoding">utf8</property>
<property name="show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.format_sql">true</property>
<mapping class="com.tcs.org.demostic.pub.security.group.bean.Group"/>
<mapping class="com.tcs.org.demostic.pub.security.user.bean.User"/>
<mapping class="com.tcs.org.demostic.pub.security.role.bean.Role"/>
<mapping class="com.tcs.org.demostic.pub.security.auth.bean.Auth"/>
<mapping class="com.tcs.org.demostic.pub.security.module.bean.Module"/>
<mapping class="com.tcs.org.demostic.pub.security.menu.bean.Menu"/>
<mapping class="com.tcs.org.demostic.pub.security.user.bean.UserDetail"/>
<mapping class="com.tcs.org.demostic.pub.security.user.bean.UserSituation"/>
</session-factory>
</hibernate-configuration>
=================================log4j.properties=========
### set log levels ###
log4j.rootLogger = debug, stdout, D, E
### \u8f93\u51fa\u5230\u63a7\u5236\u53f0 ###
#kong zhi tai
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{yyyy-MM-dd HH:mm:ss} [%t:%r] - [%p] %m%n
### \u8f93\u51fa\u5230\u65e5\u5fd7\u6587\u4ef6 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = ${webapp.root}/log/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%t:%r] - [%p] %m%n
### \u4fdd\u5b58\u5f02\u5e38\u4fe1\u606f\u5230\u5355\u72ec\u6587\u4ef6 ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File = ${webapp.root}/log/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss} [%t\:%r] - [%p] %m%n
==========================================
proxool.properties
## ##公用数据库参数配置
show_sql=true
format_sql=true
hbm2ddl.auto=update
cglib.use_reflection_optimizer=true
connection.release_mode=auto
current_session_context_class=thread
connection.autocommit=true
maxActive=300
maxIdle=30
maxWait=500
proxool.house-keeping-test-sql=select sysdate from DUAL
connection.provider_class=org.hibernate.connection.ProxoolConnectionProvider
database.connection=org.hibernate.connection.ProxoolConnectionProvider
proxool.alias=Demostic
## ## mySql ## ##
database.dialect=org.hibernate.dialect.MySQLDialect
database.driver=com.mysql.jdbc.Driver
database.url=jdbc\:mysql\://127.0.0.1\:3306/mydemo?useUnicode\=true&amp;characterEncoding\=utf-8
database.user=root
database.password=1
## ## orcale ## ##
##database.dialect=org.hibernate.dialect.OracleDialect
##database.driver=oracle.jdbc.driver.OracleDriver
##database.url=jdbc:oracle:thin:@127.0.0.1:1521:tcs
##database.user=demostic
##database.password=demostic
## ##缓存设置
hibernate.cache.provider_class=org.hibernate.cache.HashtableCacheProvider,org.hibernate.cache.EhCacheProvider
hibernate.cache.use_query_cache=false
hibernate.cache.use_second_level_cache=true
hibernate.cache.configurationResourceName=ehcache.xml
hibernate.connection.autocommit=true
## ##测试版数据库
=================================proxool.xml=====================
<?xml version="1.0" encoding="UTF-8" ?>
<something-else-entirely>
<proxool>
<alias>mydemo</alias>
<!--mysql -->
<driver-url>jdbc:mysql://localhost:3306/mydemo</driver-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<driver-properties>
<property name="user" value="root" />
<property name="password" value="1" />
</driver-properties>
<!--
oracle <driver-url>jdbc:oracle:thin:@localhost:1521:tcs</driver-url>
<driver-class>oracle.jdbc.driver.OracleDriver</driver-class>
<driver-properties> <property name="user" value="demostic" />
<property name="password" value="demostic" /> </driver-properties>
-->
<!-- 最小的数据库连接数 -->
<minimum-connection-count>10</minimum-connection-count>
<!-- 最大的数据库连接数 -->
<maximum-connection-count>500</maximum-connection-count>
<!-- 最少保持的空闲连接数 -->
<prototype-count>10</prototype-count>
<!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁。 -->
<house-keeping-sleep-time>90000</house-keeping-sleep-time>
<!-- 指因未有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受 -->
<maximum-new-connections>300</maximum-new-connections>
<!-- 某一时间点的最大连接数 -->
<simultaneous-build-throttle>150</simultaneous-build-throttle>
<!-- 一个线程持有一个连接的最长时间5分钟,单位毫秒(默认5分钟) -->
<maximum-active-time>300000</maximum-active-time>
<!-- 一个连接的最长活动时间4小时,单位毫秒(默认4小时) -->
<maximum-connection-lifetime>14400000</maximum-connection-lifetime>
<house-keeping-test-sql>set names 'UTF-8';</house-keeping-test-sql>
<test-before-use>true</test-before-use>
<house-keeping-test-sql>select 1 from dual</house-keeping-test-sql>
</proxool>
</something-else-entirely>
==========================================struts.properties==========
### Struts default properties
###(can be overridden by a struts.properties file in the root of the classpath)
###
### Specifies the Configuration used to configure Struts
### one could extend org.apache.struts2.config.Configuration
### to build one's customize way of getting the configurations parameters into Struts
# struts.configuration=org.apache.struts2.config.DefaultConfiguration
### This can be used to set your default locale and encoding scheme
# struts.locale=en_US
struts.i18n.encoding=UTF-8
### if specified, the default object factory can be overridden here
### Note: short-hand notation is supported in some cases, such as "spring"
### Alternatively, you can provide a com.opensymphony.xwork2.ObjectFactory subclass name here
struts.objectFactory = spring
### specifies the autoWiring logic when using the SpringObjectFactory.
### valid values are: name, type, auto, and constructor (name is the default)
struts.objectFactory.spring.autoWire = name
### indicates to the struts-spring integration if Class instances should be cached
### this should, until a future Spring release makes it possible, be left as true
### unless you know exactly what you are doing!
### valid values are: true, false (true is the default)
struts.objectFactory.spring.useClassCache = true
### if specified, the default object type determiner can be overridden here
### Note: short-hand notation is supported in some cases, such as "tiger" or "notiger"
### Alternatively, you can provide a com.opensymphony.xwork2.util.ObjectTypeDeterminer implementation name here
### Note: By default, com.opensymphony.xwork2.util.DefaultObjectTypeDeterminer is used which handles type detection
### using generics. com.opensymphony.xwork2.util.GenericsObjectTypeDeterminer was deprecated since XWork 2, it's
### functions are integrated in DefaultObjectTypeDeterminer now.
### To disable tiger support use the "notiger" property value here.
#struts.objectTypeDeterminer = tiger
#struts.objectTypeDeterminer = notiger
### Parser to handle HTTP POST requests, encoded using the MIME-type multipart/form-data
# struts.multipart.parser=cos
# struts.multipart.parser=pell
struts.multipart.parser=jakarta
# uses javax.servlet.context.tempdir by default
struts.multipart.saveDir=
struts.multipart.maxSize=2097152
### Load custom property files (does not override struts.properties!)
# struts.custom.properties=application,org/apache/struts2/extension/custom
### How request URLs are mapped to and from actions
#struts.mapper.class=org.apache.struts2.dispatcher.mapper.DefaultActionMapper
### Used by the DefaultActionMapper
### You may provide a comma separated list, e.g. struts.action.extension=action,jnlp,do
#struts.action.extension=do
struts.action.extension = action,do,
### Used by FilterDispatcher
### If true then Struts serves static content from inside its jar.
### If false then the static content must be available at <context_path>/struts
struts.serve.static=true
### Used by FilterDispatcher
### This is good for development where one wants changes to the static content be
### fetch on each request.
### NOTE: This will only have effect if struts.serve.static=true
### If true -> Struts will write out header for static contents such that they will
### be cached by web browsers (using Date, Cache-Content, Pragma, Expires)
### headers).
### If false -> Struts will write out header for static contents such that they are
### NOT to be cached by web browser (using Cache-Content, Pragma, Expires
### headers)
struts.serve.static.browserCache=true
### Set this to false if you wish to disable implicit dynamic method invocation
### via the URL request. This includes URLs like foo!bar.action, as well as params
### like method:bar (but not action:foo).
### An alternative to implicit dynamic method invocation is to use wildcard
### mappings, such as <action name="*/*" method="{2}" class="actions.{1}">
struts.enable.DynamicMethodInvocation = true
### Set this to true if you wish to allow slashes in your action names. If false,
### Actions names cannot have slashes, and will be accessible via any directory
### prefix. This is the traditional behavior expected of WebWork applications.
### Setting to true is useful when you want to use wildcards and store values
### in the URL, to be extracted by wildcard patterns, such as
### <action name="*/*" method="{2}" class="actions.{1}"> to match "/foo/edit" or
### "/foo/save".
struts.enable.SlashesInActionNames = false
### use alternative syntax that requires %{} in most places
### to evaluate expressions for String attributes for tags
struts.tag.altSyntax=true
### when set to true, Struts will act much more friendly for developers. This
### includes:
### - struts.i18n.reload = true
### - struts.configuration.xml.reload = true
### - raising various debug or ignorable problems to errors
### For example: normally a request to foo.action?someUnknownField=true should
### be ignored (given that any value can come from the web and it
### should not be trusted). However, during development, it may be
### useful to know when these errors are happening and be told of
### them right away.
struts.devMode = false
### when set to true, resource bundles will be reloaded on _every_ request.
### this is good during development, but should never be used in production
struts.i18n.reload=false
### Standard UI theme
### Change this to reflect which path should be used for JSP control tag templates by default
struts.ui.theme=simple
struts.ui.templateDir=template
#sets the default template type. Either ftl, vm, or jsp
struts.ui.templateSuffix=ftl
### Configuration reloading
### This will cause the configuration to reload struts.xml when it is changed
struts.configuration.xml.reload=false
### Location of velocity.properties file. defaults to velocity.properties
struts.velocity.configfile = velocity.properties
### Comma separated list of VelocityContext classnames to chain to the StrutsVelocityContext
struts.velocity.contexts =
### Location of the velocity toolbox
struts.velocity.toolboxlocation=
### used to build URLs, such as the UrlTag
struts.url.http.port = 80
struts.url.https.port = 443
### possible values are: none, get or all
struts.url.includeParams = get
### Load custom default resource bundles
struts.custom.i18n.resources=com.myshop.resources.ApplicationResources
### workaround for some app servers that don't handle HttpServletRequest.getParameterMap()
### often used for WebLogic, Orion, and OC4J
struts.dispatcher.parametersWorkaround = false
### configure the Freemarker Manager class to be used
### Allows user to plug-in customised Freemarker Manager if necessary
### MUST extends off org.apache.struts2.views.freemarker.FreemarkerManager
#struts.freemarker.manager.classname=org.apache.struts2.views.freemarker.FreemarkerManager
### Enables caching of FreeMarker templates
### Has the same effect as copying the templates under WEB_APP/templates
struts.freemarker.templatesCache=false
### Enables caching of models on the BeanWrapper
struts.freemarker.beanwrapperCache=false
### See the StrutsBeanWrapper javadocs for more information
struts.freemarker.wrapper.altMap=true
### configure the XSLTResult class to use stylesheet caching.
### Set to true for developers and false for production.
struts.xslt.nocache=false
### A list of configuration files automatically loaded by Struts
struts.configuration.files=struts-default.xml,struts-plugin.xml,struts.xml
### Whether to always select the namespace to be everything before the last slash or not
struts.mapper.alwaysSelectFullNamespace=false
============================================struts.xml=========
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "[url=http://struts.apache.org/dtds/struts-2.0.dtd]http://struts.apache.org/dtds/struts-2.0.dtd[/url]">
<struts>
<constant name="struts.i18n.encoding" value="GBK" />
<constant name="struts.locale" value="zh_CN" />
<constant name="struts.multipart.maxSize" value="300000000" />
<constant name="struts.action.extension" value="action,struts2,json,html,demo,do,htm," />
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<constant name="struts.enable.SlashesInActionNames" value="true" />
<constant name="struts.ui.theme" value="simple" />
<constant name="struts.convention.relative.result.types" value="dispatcher,freemarker,velocity" />
<constant name="struts.devMode" value="true" />
<constant name="struts.convention.classes.reload" value="true" />
<constant name="struts.convention.action.suffix" value="action,demo" />
<constant name="struts.convention.action.name.lowercase" value="true" />
<constant name="struts.convention.action.name.separator" value="-" />
<constant name="struts.custom.i18n.resources" value="com.demo.resources.ApplicationResources*" />
</struts>
==================================com.tcs.org.demostic.pub.until.ProxoolListener====
package com.tcs.org.demostic.pub.until;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.logicalcobwebs.proxool.ProxoolException;
import org.logicalcobwebs.proxool.ProxoolFacade;
import org.logicalcobwebs.proxool.configuration.JAXPConfigurator;
import org.logicalcobwebs.proxool.configuration.PropertyConfigurator;
import javax.servlet.ServletContextEvent;
import java.io.File;
import java.util.Properties;
/**
* proxool初始化
*/
public class ProxoolListener implements
javax.servlet.ServletContextListener {
private static final Log LOG = LogFactory
.getLog(ProxoolListener.class);
private static final String XML_FILE_PROPERTY = "proxoolConfigLocation";
private boolean autoShutdown = true;
public void contextInitialized(ServletContextEvent servletConfig) {
String appDir = servletConfig.getServletContext().getRealPath("/");
Properties properties = new Properties();
String value = servletConfig.getServletContext().getInitParameter(
XML_FILE_PROPERTY);
LOG.debug("proxoolConfigLocation:" + value);
try {
File file = new File(value);
if (file.isAbsolute()) {
JAXPConfigurator.configure(value, false);
} else {
LOG.debug(appDir + File.separator + value);
JAXPConfigurator.configure(appDir + File.separator + value,
false);
}
} catch (ProxoolException e) {
LOG.error("Problem configuring " + value, e);
}
if (properties.size() > 0) {
try {
PropertyConfigurator.configure(properties);
} catch (ProxoolException e) {
LOG.error("Problem configuring using init properties", e);
}
}
}
public void contextDestroyed(ServletContextEvent s) {
if (autoShutdown) {
ProxoolFacade.shutdown(0);
}
}
}
====================================annotation生成表==============
package com.tcs.org.demostic.pub.until;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
/*
*功能:生成表
*先建mysql数据库(或)
*oracle实例 (demo)
*doc/oracle--mysql create.readme
*
*/
@SuppressWarnings("deprecation")
public class createTable {
public static void main(String[] args) {
Configuration cfg = new AnnotationConfiguration().configure();
SchemaExport export = new SchemaExport(cfg);
export.create(true, true);
// SchemaUpdate update =new SchemaUpdate(cfg);
// update.execute(true, true);
}
}
==================================BASEACTION======
BaseAction.java
package com.tcs.org.demostic.pub.base.action;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONObject;
import org.apache.struts2.ServletActionContext;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;
import com.opensymphony.xwork2.ActionSupport;
/**
*
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 <br>
* <p>
*/
@SuppressWarnings("serial")
@Controller
@Scope("prototype")
public class BaseAction extends ActionSupport {
private int page;
private String msg;
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
}
=========================PageIndex.java===================
package com.tcs.org.demostic.pub.base.bean;
/**
* 页索引,主要是起始页和终止页 $
*
* @author Jar.lin $<br>
*
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
public class PageIndex {
/** 开始索引 **/
private int startIndex;
/** 结束索引 **/
private int endIndex;
public PageIndex(int startIndex, int endIndex) {
this.startIndex = startIndex;
this.endIndex = endIndex;
}
public int getStartIndex() {
return startIndex;
}
public void setStartIndex(int startIndex) {
this.startIndex = startIndex;
}
public int getEndIndex() {
return endIndex;
}
public void setEndIndex(int endIndex) {
this.endIndex = endIndex;
}
/**
* 起始页和终止页
*
* @param viewPageCount
* 显示多少页
* @param currentPage
* 当前页
* @param totalpage
* 总页数
* @return PageIndex 起始页和终止页
*/
public static PageIndex getPageIndex(int viewPageCount, int currentPage,
int totalpage) {
int startpage = currentPage
- (viewPageCount % 2 == 0 ? viewPageCount / 2 - 1
: viewPageCount / 2);
int endpage = currentPage + viewPageCount / 2;
if (startpage < 1) {
startpage = 1;
if (totalpage >= viewPageCount)
endpage = viewPageCount;
else
endpage = totalpage;
}
if (endpage > totalpage) {
endpage = totalpage;
if ((endpage - viewPageCount) > 0)
startpage = endpage - viewPageCount + 1;
else
startpage = 1;
}
return new PageIndex(startpage, endpage);
}
}
==============================PageView.java===================
package com.tcs.org.demostic.pub.base.bean;
import java.util.List;
/**
* * 分页数据包装,包括分页信息和List数据 $<br>
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
public class PageView<T> {
/** 分页数据 **/
private List<T> records;
/** 页码开始索引和结束索引 **/
private PageIndex pageIndex;
/** 总页数 **/
private int totalPage = 1;
/** 每页显示记录数 **/
private int maxResult = 10;
/** 当前页 **/
private int currentPage = 1;
/** 总记录数 **/
private int totalRecord;
/** 每次显示多少页,必须保证大于3页,保证左右链接都可以使用 **/
private int viewPageCount = 10;
/** 要获取记录的开始索引 **/
public int getFirstResult() {
return (this.currentPage - 1) * this.maxResult;
}
public int getViewPageCount() {
return viewPageCount;
}
public void setViewPageCount(int viewPageCount) {
this.viewPageCount = viewPageCount;
}
public PageView(int maxResult, int currentPage) {
this.maxResult = maxResult;
this.currentPage = (currentPage <= 0 ? 1 : currentPage);
}
public PageView(int currentPage) {
this.currentPage = (currentPage <= 0 ? 1 : currentPage);
}
public void setQueryResult(QueryResult<T> qr) {
setTotalRecord(qr.getTotalRecord());
setRecords(qr.getResultList());
}
public int getTotalRecord() {
return totalRecord;
}
public void setTotalRecord(int totalRecord) {
this.totalRecord = totalRecord;
setTotalPage(this.totalRecord % this.maxResult == 0 ? this.totalRecord
/ this.maxResult : this.totalRecord / this.maxResult + 1);
}
public List<T> getRecords() {
return records;
}
public void setRecords(List<T> records) {
this.records = records;
}
public PageIndex getPageIndex() {
return pageIndex;
}
public int getTotalPage() {
return totalPage;
}
public void setTotalPage(int totalPage) {
this.totalPage = totalPage;
this.pageIndex = PageIndex.getPageIndex(viewPageCount, currentPage,
totalPage);
}
public int getMaxResult() {
return maxResult;
}
public int getCurrentPage() {
return currentPage;
}
}
======================QueryResult.java===============================
package com.tcs.org.demostic.pub.base.bean;
import java.util.List;
/**
**查询结果集,包括数据和总数 $<br>
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
public class QueryResult<T> {
/** 查询得出的数据List **/
private List<T> resultList;
/** 查询得出的总数 **/
private int totalRecord;
public List<T> getResultList() {
return resultList;
}
public void setResultList(List<T> resultList) {
this.resultList = resultList;
}
public int getTotalRecord() {
return totalRecord;
}
public void setTotalRecord(int totalRecord) {
this.totalRecord = totalRecord;
}
}
==========================BaseDAOImpl.JAVA========================
package com.tcs.org.demostic.pub.base.dao.impl;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.io.Serializable;
import java.lang.reflect.Method;
import java.sql.SQLException;
import java.util.LinkedHashMap;
import java.util.List;
import javax.annotation.Resource;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.tcs.org.demostic.pub.base.bean.QueryResult;
import com.tcs.org.demostic.pub.base.dao.IBaseDao;
import com.tcs.org.demostic.pub.base.util.GenericsUtils;
/**
* DAO层封装使用了泛型,包含常用的CURD和分页操作
*
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
@SuppressWarnings("unchecked")
public abstract class BaseDaoImpl<T> extends HibernateDaoSupport implements IBaseDao<T> {
protected Class<T> entityClass = GenericsUtils.getSuperClassGenricType(this.getClass());
protected String entityClassName = getEntityName(this.entityClass);
protected String keyFieldName = getKeyFieldName(this.entityClass);
// 为父类HibernateDaoSupport注入sessionFactory的值
@Resource(name = "sessionFactory")
public void setSuperSessionFactory(SessionFactory sessionFactory) {
super.setSessionFactory(sessionFactory);
}
/*
* @see findByEntity(java.lang.Object)
*/
public List<T> findByEntity(Object entiey)throws Exception {
return super.getHibernateTemplate().findByExample(entiey);
}
/*
* Order By
*
*/
public List<T> findByEntityOrderBy(Object entiey,String orderBy,String descasc)throws Exception{
String entieyOrderBy = "from" +entityClassName+ " o Order By " + orderBy +" "+descasc;
return super.getHibernateTemplate().find(entieyOrderBy);
}
/*
* @see findByProperty(java.lang.String, java.lang.Object)
*/
public List<T> findByProperty(String propertyName, Object value)throws Exception {
String queryString = "from " + entityClassName + " o where o."
+ propertyName + "= ?";
return super.getHibernateTemplate().find(queryString, value);
}
/*
* @see find(java.io.Serializable)
*/
public T find(Serializable entityId) throws Exception {
if (null != entityId)
return (T) super.getHibernateTemplate().get(entityClass, entityId);
return null;
}
/*
* @see getCount()
*/
public int getCount() throws Exception {
String hql = "select count( " + keyFieldName + ") from "
+ entityClassName;
int count = Integer.parseInt(super.getHibernateTemplate().find(hql)
.get(0).toString());
return count;
}
public void save(Object entity) throws Exception {
super.getHibernateTemplate().save(entity);
}
/*
* @see update(java.lang.Object)
*/
public void update(Object entity) throws Exception {
super.getHibernateTemplate().update(entity);
}
public void saveOrUpdate(Object entity) {
super.getHibernateTemplate().saveOrUpdate(entity);
}
/*
* @see delete(java.io.Serializable[])
*/
public void delete(Serializable... entityids) throws Exception {
for (Object id : entityids) {
super.getHibernateTemplate().delete(find((Serializable) id));
}
}
/*
* @see getScrollData(int, int, java.lang.String,
* java.lang.Object[], java.util.LinkedHashMap)
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult,
final String wherejpql,
final Object[] queryParams,
final LinkedHashMap<String, String> orderby) throws Exception {
final QueryResult<T> queryResult = new QueryResult<T>();
super.getHibernateTemplate().execute(new HibernateCallback<T>() {
public T doInHibernate(Session session) throws HibernateException,
SQLException {
String hql = "from "
+ entityClassName
+ " o "
+ (wherejpql == null || "".equals(wherejpql.trim()) ? ""
: " where " + wherejpql)
+ buildOrderby(orderby);
Query query = session.createQuery(hql);
setQueryParams(query, queryParams);// where
queryResult.setTotalRecord(query.list().size());// first get
// size
if (firstindex != -1 && maxresult != -1)
query.setFirstResult(firstindex).setMaxResults(maxresult);// last
// page
queryResult.setResultList(query.list());
return null;
}
});
return queryResult;
}
/*
* @see getScrollData(int, int, java.lang.String,
* java.lang.Object[], java.util.LinkedHashMap)
*
* SELECT 语句
SELECT[predicate]{*|table.*|[table.]field [,[table.]field2[,...]]} [AS alias1 [,alias2[,...]]]
FROM tableexpression [,...][IN externaldatabase]
[]
[WHERE...]
[GROUP BY...]
[HAVING...]
[ORDER BY...]
[WITH OWNERACCESS OPTION]
SELECT 语句包括下面几个部分
predicate
*/
/*
* @see getScrollData(int, int, java.lang.String,
* java.lang.Object[])
*/
public QueryResult<T> getScrollData(int firstindex, int maxresult,
String wherejpql, Object[] queryParams)throws Exception {
return getScrollData(firstindex, maxresult, wherejpql, queryParams,
null);
}
/*
* @see getScrollData(int, int, java.util.LinkedHashMap)
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult, final LinkedHashMap<String, String> orderby) throws Exception {
return getScrollData(firstindex, maxresult, null, null, orderby);
}
/*
* @see getScrollData(int, int)
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult) throws Exception {
return getScrollData(firstindex, maxresult, null, null, null);
}
/*
* @see getScrollData()
*/
public QueryResult<T> getScrollData() throws Exception {
return getScrollData(-1, -1, null, null, null);
}
/*
* @see save(java.lang.Object)
*/
/**
* 获取实体的名称
*
* @param <E>
* @param clazz
* 实体类
* @return
*/
protected static <E> String getEntityName(Class<E> clazz) {
String entityname = clazz.getSimpleName();
Entity entity = clazz.getAnnotation(Entity.class);
if (entity.name() != null && !"".equals(entity.name())) {
entityname = entity.name();
}
return entityname;
}
/**
* 获取实体的主键
*
* @param <E>
* @param clazz
* 实体类
* @return 主键名
*/
protected static <E> String getKeyFieldName(Class<E> clazz) {
try {
PropertyDescriptor[] propertyDescriptors = Introspector
.getBeanInfo(clazz).getPropertyDescriptors();
for (PropertyDescriptor propertydesc : propertyDescriptors) {
Method method = propertydesc.getReadMethod();
if (null != method
&& null != method
.getAnnotation(javax.persistence.Id.class)) {
return propertydesc.getName();
}
}
} catch (Exception e) {
e.printStackTrace();
}
return "id";
}
/**
* 设置HQL里边的属性值
*
* @param query
* @param queryParams
*/
protected static void setQueryParams(Query query, Object[] queryParams) {
if (queryParams != null && queryParams.length > 0) {
for (int i = 0; i < queryParams.length; i++) {
query.setParameter(i, queryParams[i]);// 从0开始
}
}
}
/**
* 组装order by语句
*
* @param orderby
* @return
*/
protected static String buildOrderby(LinkedHashMap<String, String> orderby) {
StringBuffer orderbyql = new StringBuffer("");
if (orderby != null && orderby.size() > 0) {
orderbyql.append(" order by ");
for (String key : orderby.keySet()) {
orderbyql.append("o.").append(key).append(" ").append(
orderby.get(key)).append(",");
}
orderbyql.deleteCharAt(orderbyql.length() - 1);
}
return orderbyql.toString();
}
protected static <E> String getCountField(Class<E> clazz) throws Exception {
String out = "o";
try {
PropertyDescriptor[] propertyDescriptors = Introspector
.getBeanInfo(clazz).getPropertyDescriptors();
for (PropertyDescriptor propertydesc : propertyDescriptors) {
Method method = propertydesc.getReadMethod();
if (method != null
&& method.isAnnotationPresent(EmbeddedId.class)) {
PropertyDescriptor[] ps = Introspector.getBeanInfo(
propertydesc.getPropertyType())
.getPropertyDescriptors();
out = "o."
+ propertydesc.getName()
+ "."
+ (!ps[1].getName().equals("class") ? ps[1]
.getName() : ps[0].getName());
break;
}
}
} catch (Exception e) {
e.printStackTrace();
}
return out;
}
}
=============================IBASEDAO.JAVA========================
package com.tcs.org.demostic.pub.base.dao;
import java.io.Serializable;
import java.util.LinkedHashMap;
import java.util.List;
import com.tcs.org.demostic.pub.base.bean.QueryResult;
/**
* DAO层封装接口,包含常用的CURD和分页操作 $<br>
*
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
public interface IBaseDao<T> {
/**
* 根据属性查找对象
*
* @param propertyName
* 属性(对应Bean)
* @param value
* 属性
* @return 根据属性查找对象
*/
public List<T> findByProperty(String propertyName, Object value) throws Exception;
/**
* 根据实体查找对象
*
* @param entiey
* 实体(T类型)
* @return 根据属性查找对象
*/
public List<T> findByEntity(Object entiey)throws Exception;
/**
* 获取记录总数
*
* @param entityClass
* 实体类
* @return
*/
public int getCount()throws Exception;
/**
* 保存实体
*
* @param entity
* 实体id
*/
public void save(Object entity)throws Exception;
/**
* 更新实体
*
* @param entity
* 实体id
*/
public void update(Object entity)throws Exception;
/**
* 更新或保存实体
*
* @param entity
* 实体id
*/
public void saveOrUpdate(Object entity)throws Exception;
/**
* 删除实体
*
* @param entityClass
* 实体类
* @param entityids
* 实体id数组
*/
public void delete(Serializable... entityids)throws Exception;
/**
* 获取实体
*
* @param <T>
* @param entityClass
* 实体类
* @param entityId
* 实体id
* @return
*/
public T find(Serializable entityId)throws Exception;
/**
* 获取分页数据
*
* @param firstindex
* 开始索引
* @param maxresult
* 每页显示记录数
* @param wherejpql
* where语句
* @param queryParams
* 查询参数
* @param orderby
* 排序序列
* @return 分页数据
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult, final String wherejpql,
final Object[] queryParams,
final LinkedHashMap<String, String> orderby)throws Exception;
/**
* 获取分页数据
*
* @param firstindex
* 开始索引
* @param maxresult
* 每页显示记录数
* @param wherejpql
* where语句
* @param queryParams
* 查询参数
* @return 分页数据
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult, final String wherejpql,
final Object[] queryParams)throws Exception;
/**
* 获取分页数据
*
* @param firstindex
* 开始索引
* @param maxresult
* 每页显示记录数
* @param orderby
* 排序序列
* @return 分页数据
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult, final LinkedHashMap<String, String> orderby)throws Exception;
/**
* 获取分页数据
*
* @param firstindex
* 开始索引
* @param maxresult
* 每页显示记录数
* @return 分页数据
*/
public QueryResult<T> getScrollData(final int firstindex,
final int maxresult)throws Exception;
/**
* 获取所有对象
*
* @return 所有对象
*/
public QueryResult<T> getScrollData()throws Exception;
}
==========================GENERICEuTILS=============================
package com.tcs.org.demostic.pub.base.util;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.List;
/**
* 泛型工具类 $<br>
*
* @author Jar.lin $<br>
* @notes Created on 2010-01-25 $<br>
* Revision of last commit:$Revision: 01 $<br>
* Author of last commit:$Author: [email protected] $<br>
* Date of last commit:$Date: 2010-01-25 16:47:12 +0800 (周一, 25 一月 2010)$<br>
* <p>
*/
public class GenericsUtils {
/**
* 通过反射,获得指定类的父类的泛型参数的实际类型. 如BuyerServiceBean extends DaoSupport<Buyer>
*
* @param clazz
* clazz 需要反射的类,该类必须继承范型父类
* @param index
* 泛型参数所在索引,从0开始.
* @return 范型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getSuperClassGenricType(Class clazz, int index) {
Type genType = clazz.getGenericSuperclass();// 得到泛型父类
// 如果没有实现ParameterizedType接口,即不支持泛型,直接返回Object.class
if (!(genType instanceof ParameterizedType)) {
return Object.class;
}
// 返回表示此类型实际类型参数的Type对象的数组,数组里放的都是对应类型的Class, 如BuyerServiceBean extends
// DaoSupport<Buyer,Contact>就返回Buyer和Contact类型
Type[] params = ((ParameterizedType) genType).getActualTypeArguments();
if (index >= params.length || index < 0) {
throw new RuntimeException("你输入的索引"
+ (index < 0 ? "不能小于0" : "超出了参数的总数"));
}
if (!(params[index] instanceof Class)) {
return Object.class;
}
return (Class) params[index];
}
/**
* 通过反射,获得指定类的父类的第一个泛型参数的实际类型. 如BuyerServiceBean extends DaoSupport<Buyer>
*
* @param clazz
* clazz 需要反射的类,该类必须继承泛型父类
* @return 泛型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getSuperClassGenricType(Class clazz) {
return getSuperClassGenricType(clazz, 0);
}
/**
* 通过反射,获得方法返回值泛型参数的实际类型. 如: public Map<String, Buyer> getNames(){}
*
* @param Method
* method 方法
* @param int index 泛型参数所在索引,从0开始.
* @return 泛型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getMethodGenericReturnType(Method method, int index) {
Type returnType = method.getGenericReturnType();
if (returnType instanceof ParameterizedType) {
ParameterizedType type = (ParameterizedType) returnType;
Type[] typeArguments = type.getActualTypeArguments();
if (index >= typeArguments.length || index < 0) {
throw new RuntimeException("你输入的索引"
+ (index < 0 ? "不能小于0" : "超出了参数的总数"));
}
return (Class) typeArguments[index];
}
return Object.class;
}
/**
* 通过反射,获得方法返回值第一个泛型参数的实际类型. 如: public Map<String, Buyer> getNames(){}
*
* @param Method
* method 方法
* @return 泛型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getMethodGenericReturnType(Method method) {
return getMethodGenericReturnType(method, 0);
}
/**
* 通过反射,获得方法输入参数第index个输入参数的所有泛型参数的实际类型. 如: public void add(Map<String,
* Buyer> maps, List<String> names){}
*
* @param Method
* method 方法
* @param int index 第几个输入参数
* @return 输入参数的泛型参数的实际类型集合, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回空集合
*/
@SuppressWarnings("unchecked")
public static List<Class> getMethodGenericParameterTypes(Method method,
int index) {
List<Class> results = new ArrayList<Class>();
Type[] genericParameterTypes = method.getGenericParameterTypes();
if (index >= genericParameterTypes.length || index < 0) {
throw new RuntimeException("你输入的索引"
+ (index < 0 ? "不能小于0" : "超出了参数的总数"));
}
Type genericParameterType = genericParameterTypes[index];
if (genericParameterType instanceof ParameterizedType) {
ParameterizedType aType = (ParameterizedType) genericParameterType;
Type[] parameterArgTypes = aType.getActualTypeArguments();
for (Type parameterArgType : parameterArgTypes) {
Class parameterArgClass = (Class) parameterArgType;
results.add(parameterArgClass);
}
return results;
}
return results;
}
/**
* 通过反射,获得方法输入参数第一个输入参数的所有泛型参数的实际类型. 如: public void add(Map<String, Buyer>
* maps, List<String> names){}
*
* @param Method
* method 方法
* @return 输入参数的泛型参数的实际类型集合, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回空集合
*/
@SuppressWarnings("unchecked")
public static List<Class> getMethodGenericParameterTypes(Method method) {
return getMethodGenericParameterTypes(method, 0);
}
/**
* 通过反射,获得Field泛型参数的实际类型. 如: public Map<String, Buyer> names;
*
* @param Field
* field 字段
* @param int index 泛型参数所在索引,从0开始.
* @return 泛型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getFieldGenericType(Field field, int index) {
Type genericFieldType = field.getGenericType();
if (genericFieldType instanceof ParameterizedType) {
ParameterizedType aType = (ParameterizedType) genericFieldType;
Type[] fieldArgTypes = aType.getActualTypeArguments();
if (index >= fieldArgTypes.length || index < 0) {
throw new RuntimeException("你输入的索引"
+ (index < 0 ? "不能小于0" : "超出了参数的总数"));
}
return (Class) fieldArgTypes[index];
}
return Object.class;
}
/**
* 通过反射,获得Field泛型参数的实际类型. 如: public Map<String, Buyer> names;
*
* @param Field
* field 字段
* @param int index 泛型参数所在索引,从0开始.
* @return 泛型参数的实际类型, 如果没有实现ParameterizedType接口,即不支持泛型,所以直接返回
* <code>Object.class</code>
*/
@SuppressWarnings("unchecked")
public static Class getFieldGenericType(Field field) {
return getFieldGenericType(field, 0);
}
}
=======================================================
<Context path="/mydemo" docBase="D:\dev\myTools\workspace\mydemo\target\mydemo\webapp" debug="3" reloadable="true"/>