• Spring学习笔记(马士兵spring视频笔记)


    课程内容

    1. 面向接口(抽象)编程的概念与好处

    2. IOC/DI的概念与好处

    a) inversion of control

    b) dependency injection

    3. AOP的概念与好处

    4. Spring简介

    5. Spring应用IOC/DI(重要)

    a) xml

    b) annotation

    6. Spring应用AOP(重要)

    a) xml

    b) annotation

    7. Struts2.1.6 + Spring2.5.6 + Hibernate3.3.2整合(重要)

    a) opensessionInviewfilter(记住,解决什么问题,怎么解决)

    8. Spring JDBC

    面向接口编程(面向抽象编程)

    1. 场景:用户添加

    2. Spring_0100_AbstractOrientedProgramming

    a) 不是AOP:Aspect Oriented Programming

    3. 好处:灵活

    什么是IOCDI),有什么好处

    1. 把自己new的东西改为由容器提供

    a) 初始化具体值

    b) 装配

    2. 好处:灵活装配

    Spring简介

    1. 项目名称:Spring_0200_IOC_Introduction

    2. 环境搭建

    a) 只用IOC

    i. spring.jar , jarkata-commons/commons-loggin.jar

    3. IOC容器

    a) 实例化具体bean

    b) 动态装配

    4. AOP支持

    a) 安全检查

    b) 管理transaction

    Spring IOC配置与应用

    1. FAQ:不给提示:

    a) window – preferences – myeclipse – xml – xml catalog

    b) User Specified Entries – add

    i. Location: D:share900_Springsoftspring-framework-2.5.6dist esourcesspring-beans-2.5.xsd

    ii. URI:    file:///D:/share/0900_Spring/soft/spring-framework-2.5.6/dist/resources/spring-beans-2.5.xsd

    iii. Key Type: Schema Location

    iv. Key: http://www.springframework.org/schema/beans/spring-beans-2.5.xsd

    2. 注入类型

    a) Spring_0300_IOC_Injection_Type

    b) setter(重要)

    c) 构造方法(可以忘记)

    d) 接口注入(可以忘记)

    3. id vs. name

    a) Spring_0400_IOC_Id_Name

    b) name可以用特殊字符  <bean id/name="u" class="com.bjsxt.dao.impl.UserDAOImpl">

    4. 简单属性的注入

    a) Spring_0500_IOC_SimpleProperty

    b) <property name=… value=….> 

                (因为是基础数据类型,其实我们自己写很少遇到这样的Spring整合自己时,可以用到)

               

    5. <bean 中的scope属性

    a) Spring_0600_IOC_Bean_Scope

    b) singleton 单例

    c) proptotype 每次创建新的对象

    6. 集合注入

    a) Spring_0700_IOC_Collections

    b) 很少用,不重要!参考程序

    7. 自动装配

    a) Spring_0800_IOC_AutoWire

    b) byName

    c) byType

    d) 如果所有的bean都用同一种,可以使用beans的属性:default-autowire

    8. 生命周期

    a) Spring_0900_IOC_Life_Cycle

    b) lazy-init (不重要)

    c) init-method destroy-methd 不要和prototype一起用(了解)

    9. Annotation第一步:

    a) 修改xml文件,参考文档<context:annotation-config />

    10. @Autowired

    a) 默认按类型by type

    b) 如果想用byName,使用@Qulifier

    c) 写在private field(第三种注入形式)(不建议,破坏封装)

    d) 如果写在set上,@qualifier需要写在参数上

    11. @Resource(重要)

    a) 加入:j2ee/common-annotations.jar

    b) 默认按名称,名称找不到,按类型

    c) 可以指定特定名称

    d) 推荐使用

    e) 不足:如果没有源码,就无法运用annotation,只能使用xml

    12. @Component @Service @Controller @Repository

    a) 初始化的名字默认为类名首字母小写

    b) 可以指定初始化bean的名字

    13. @Scope

    14. @PostConstruct = init-method; @PreDestroy = destroy-method;

    什么是AOP

    1. 面向切面编程Aspect-Oriented-Programming

    a) 是对面向对象的思维方式的有力补充

    2. Spring_1400_AOP_Introduction

    3. 好处:可以动态的添加和删除在切面上的逻辑而不影响原来的执行代码

    a) Filter

    b) Struts2interceptor

    4. 概念:

    a) JoinPoint  释意:切面与原方法交接点 即 切入点

    b) PointCut  释意:切入点集合

    c) Aspect(切面)释意:可理解为代理类前说明

    d) Advice 释意:可理解为代理方法前说明 例如@Before

    e) Target  释意:被代理对象 被织入对象

    f) Weave  释意:织入

    Spring AOP配置与应用

    1. 两种方式:

    a) 使用Annotation

    b) 使用xml

    2. Annotation

    a) 加上对应的xsd文件spring-aop.xsd

    b) beans.xml <aop:aspectj-autoproxy />

    c) 此时就可以解析对应的Annotation

    d) 建立我们的拦截类

    e) 用@Aspect注解这个类

    f) 建立处理方法

    g) 用@Before来注解方法

    h) 写明白切入点(execution …….

    i) 让spring对我们的拦截器类进行管理@Component

    3. 常见的Annotation:

    a) @Pointcut  切入点声明 以供其他方法使用 例子如下:

    @Aspect

    @Component

    public class LogInterceptor {

    @Pointcut("execution(public * com.bjsxt.dao..*.*(..))")

    public void myMethod(){}

    @Around("myMethod()")

    public void before(ProceedingJoinPoint pjp) throws Throwable{

    System.out.println("method before");

    pjp.proceed();

    }

    @AfterReturning("myMethod()")

    public void afterReturning() throws Throwable{

    System.out.println("method afterReturning");

    }

    @After("myMethod()")

    public void afterFinily() throws Throwable{

    System.out.println("method end");

    }

    }

    b) @Before 发放执行之前织入

    c) @AfterReturning 方法正常执行完返回之后织入(无异常)

    d) @AfterThrowing 方法抛出异常后织入

    e) @After 类似异常的finally 

    f) @Around 环绕 类似filter , 如需继续往下执行则需要像filter中执行FilterChain.doFilter(..)对象一样 执行 ProceedingJoinPoint.proceed()方可,例子如下:

    @Around("execution(* com.bjsxt.dao..*.*(..))")

    public void before(ProceedingJoinPoint pjp) throws Throwable{

    System.out.println("method start");

    pjp.proceed();//类似FilterChain.doFilter(..)告诉jvm继续向下执行

    }

    4. 织入点语法

    a) void !void

    b) 参考文档(* ..

    如果 execution(* com.bjsxt.dao..*.*(..))中声明的方法不是接口实现 则无法使用AOP实现动态代理,此时可引入包” cglib-nodep-2.1_3.jar” 后有spring自动将普通类在jvm中编译为接口实现类,从而打到可正常使用AOP的目的.

    5. xml配置AOP

    a) 把interceptor对象初始化

    b) <aop:config

    i. <aop:aspect …..

    1. <aop:pointcut

    2. <aop:before

    例子:

    <bean id="logInterceptor" class="com.bjsxt.aop.LogInterceptor"></bean>

    <aop:config>

    <!-- 配置一个切面 -->

    <aop:aspect id="point" ref="logInterceptor">

    <!-- 配置切入点,指定切入点表达式 -->

    <!-- 此句也可放到 aop:aspect标签外 依然有效-->

    <aop:pointcut

    expression=

    "execution(public * com.bjsxt.service..*.*(..))"

    id="myMethod" />

    <!-- 应用前置通知 -->

    <aop:before method="before" pointcut-ref="myMethod" />

    <!-- 应用环绕通知 需指定向下进行 -->

    <aop:around method="around" pointcut-ref="myMethod" />

    <!-- 应用后通知 -->

    <aop:after-returning method="afterReturning"

    pointcut-ref="myMethod" />

    <!-- 应用抛出异常后通知 -->

    <aop:after-throwing method="afterThrowing"

    pointcut-ref="myMethod" />

    <!-- 应用最终通知  -->

    <aop:after method="afterFinily"

    pointcut="execution(public * om.bjsxt.service..*.*(..))" />

    </aop:aspect>

    </aop:config>

    Spring整合Hibernate

    1. Spring 指定datasource

    a) 参考文档,找dbcp.BasicDataSource

    i. c3p0

    ii. dbcp

    iii. proxool

    b) 在DAO或者Service中注入dataSource

    c) 在Spring中可以使用PropertyPlaceHolderConfigure来读取Properties文件的内容

    2. Spring整合Hibernate

    a) <bean .. AnnotationSessionFactoryBean>

    i. <property dataSource

    ii. <annotatedClasses

    b) 引入hibernate 系列jar

    c) User上加Annotation

    d) UserDAO或者UserServie 注入SessionFactory

    e) jar包问题一个一个解决

    3. 声明式的事务管理

    a) 事务加在DAO层还是Service层?

    b) annotation

    i. 加入annotation.xsd

    ii. 加入txManager bean

    iii. <tx:annotation-driven

    例如: <bean id="transactionManager"     class="org.springframework.orm.hibernate3.HibernateTransactionManager">

              <property name="sessionFactory">

                <ref bean="sessionFactory" />

              </property>

        </bean>

        <tx:annotation-driven transaction-manager="transactionManager"/>

    iv. 在需要事务的方法上加:@Transactional

    v. 需要注意,Hibernate获得session时要使用SessionFactory.getCurrentSession 不能使用OpenSession

    c) @Transactional详解

    i. 什么时候rollback 

    1. 运行期异常,非运行期异常不会触发rollback

    2. 必须uncheck (没有catch)

    3. 不管什么异常,只要你catch了,spring就会放弃管理

    4. 事务传播特性:propagation_required

    例如: @Transactional(propagation=Propagation.REQUIRED)等同于(@Transactional)

    作用,一个方法声明了@Transactional事务后,其内再调用的方法不需要再声明@Transactional.

    5. read_only

    例如: @Transactional(propagation=Propagation.REQUIRED,readOnly=true)

    当方法声明readOnly=true,该方法及其调用的方法内都不执行insert update

    d) xml(推荐,可以同时配置好多方法)

    i. <bean txmanager

    ii. <aop:config 

    1. <aop:pointcut

    2. <aop:advisor pointcut-ref advice-ref

    iii. <tx:advice: id transaction-manager = 

    iv. <property name="packagesToScan">  可定义扫描目标包下所有实体类

    例如: <bean id="sessionFactory"

         class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">

        <property name="dataSource" ref="dataSource" />

        <property name="hibernateProperties">

    <props>

    <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>

    <prop key="hibernate.show_sql">true</prop>   

    </props>

    </property>

    <!-- 

         <property name="annotatedClasses">

         <list>

         <value>com.bjsxt.model.TestUser</value>

         <value>com.bjsxt.model.Log</value>

         </list>

         </property>

          -->

          <!-- 将参数名称设为packagesToScan 可定义扫描目标包下所有实体类 -->

         <property name="packagesToScan">

         <list>

         <value>com.bjsxt.model</value>

         </list>

         </property>

        </bean>

    //事务管理@transactional的注入

    <bean id="transactionManager"

            class="org.springframework.orm.hibernate3.HibernateTransactionManager">

            <property name="sessionFactory">

                <ref bean="sessionFactory" />

            </property>

        </bean>

        //定义字符串“execution()”为一个变量名,简化

        <aop:config>

            <aop:pointcut

    expression="execution(public * com.bjsxt.service..*.*(..))"

    id="myServiceMethod" />

            <aop:advisor pointcut-ref="myServiceMethod" advice-ref="txAdvice"/>

        </aop:config>

        

        <tx:advice id="txAdvice" transaction-manager="transactionManager">

            <tx:attributes>

                <tx:method name="save*" propagation="REQUIRED" />

                <tx:method name="add*" propagation="REQUIRED" />

                <tx:method name="update*" propagation="REQUIRED" />

                <tx:method name="del*" propagation="REQUIRED" />

                <tx:method name="cancel*" propagation="REQUIRED" />

                <tx:method name="*" read-only="true" /> 

            </tx:attributes>

        </tx:advice>

    e) HibernateTemplateHibernateCallbackHibernateDaoSupport(不重要)介绍

    i. 设计模式:Template Method(模板方法)

    ii. Callback:回调/钩子函数

    iii. 第一种:(建议)

    1. 在spring中初始化HibernateTemplate,注入sessionFactory

    <bean id="hibernateTemplate" 

    class="org.springframework.orm.hibernate3.HibernateTemplate">

    <property name="sessionFactory" ref="sessionFactory" />

    </bean>

    2. DAO里注入HibernateTemplate

    private HibernateTemplate hibernateTemplate;

     

    @Resource

    public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {

    this.hibernateTemplate = hibernateTemplate;

    }

    3. savegetHibernateTemplate.save();

    public void save(TestUser testUser) {

    hibernateTemplate.save(testUser);

    }

    iv. 第二种:

    1. 从HibernateDaoSupport继承(此方法不好用 可忽略)

    2. 必须写在xml文件中,无法使用Annotation,因为set方法在父类中,而且是final

    例如:

    首先,新建SuperDAOImpl(使用Annotation注入--@Component):

    @Component

    public class SuperDAOImpl {

    private HibernateTemplate hibernateTemplate; //此处定义由spring注入管理

    public HibernateTemplate getHibernateTemplate() {

    return hibernateTemplate;

    }

    @Resource

    public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {

    this.hibernateTemplate = hibernateTemplate;

    }

    }

    此时,xml中必须要有:

    <bean id="hibernateTemplate" 

    class="org.springframework.orm.hibernate3.HibernateTemplate">

    <property name="sessionFactory" ref="sessionFactory" />

    </bean>

    或者,SuperDAOImpl类写成下面代码:

    @Component

    public class SuperDAOImpl extends HibernateDaoSupport {

    @Resource(name="sessionFactory")

    public void setSuperHibernateTemplate(SessionFactory sessionFactory) {

    super.setSessionFactory(sessionFactory);

    }

    }

    对应的xml中则可省略

    <bean id="hibernateTemplate"………部分

    只要包含

    <bean id="sessionFactory"……..部分即可

     

    最后,其他类继承SuperDaoImpl类后便可直接使用HibernateTemplate

    @Component("u")

    public class UserDAOImpl extends SuperDAOImpl implements UserDAO {

    public void save(TestUser testUser) {

    this.getHibernateTemplate().save(testUser);

    }

    }

    f) spring整合hibernate的时候使用packagesToScan属性,可以让spring自动扫描对应包下面的实体类

    Struts2.1.6 + Spring2.5.6 + Hibernate3.3.2

    1. 需要的jar包列表

    jar包名称

    所在位置

    说明

    antlr-2.7.6.jar

    hibernate/lib/required

    解析HQL

    aspectjrt

    spring/lib/aspectj

    AOP

    aspectjweaver

    ..

    AOP

    cglib-nodep-2.1_3.jar

    spring/lib/cglib

    代理,二进制增强

    common-annotations.jar

    spring/lib/j2ee

    @Resource

    commons-collections-3.1.jar

    hibernate/lib/required

    集合框架

    commons-fileupload-1.2.1.jar

    struts/lib

    struts

    commons-io-1.3.2

    struts/lib

    struts

    commons-logging-1.1.1

    单独下载,删除1.0.4(struts/lib)

    struts

    spring

    dom4j-1.6.1.jar

    hibernate/required

    解析xml

    ejb3-persistence

    hibernate-annotation/lib

    @Entity

    freemarker-2.3.13

    struts/lib

    struts

    hibernate3.jar

    hibernate

    hibernate-annotations

    hibernate-annotation/

    hibernate-common-annotations

    hibernate-annotation/lib

    javassist-3.9.0.GA.jar

    hiberante/lib/required

    hibernate

    jta-1.1.jar

    ..

    hibernate transaction

    junit4.5

    mysql-

    ognl-2.6.11.jar

    struts/lib

    slf4j-api-1.5.8.jar

    hibernate/lib/required

    hibernate-log

    slf4j-nop-1.5.8.jar

    hibernate/lib/required

    spring.jar

    spring/dist

    struts2-core-2.1.6.jar

    struts/lib

    xwork-2.1.2.jar

    struts/lib

    struts2

    commons-dbcp

    spring/lib/jarkata-commons

    commons-pool.jar

    ..

    struts2-spring-plugin-2.1.6.jar

    struts/lib

    2. BestPractice

    a) 将这些所有的jar包保存到一个位置,使用的时候直接copy

    3. 步骤

    a) 加入jar

    b) 首先整合Spring + Hibernate

    i. 建立对应的package

    1. dao / dao.impl / model / service / service.impl/ test

    ii. 建立对应的接口与类框架

    1. S2SH_01

    iii. 建立spring的配置文件(建议自己保留一份经常使用的配置文件,以后用到的时候直接copy改)

    iv. 建立数据库

    v. 加入Hibernate注解

    1. 在实体类上加相应注解@Entity @Id

    在字段属性的get方法上加--@Column(name = "表字段名")

    2. 在beans配置文件配置对应的实体类,使之受管

    vi. 写dao service的实现

    vii. 加入Spring注解

    1. 在对应ServiceDAO实现中加入@Component,让spring对其初始化

    2. 在Service上加入@Transactional或者使用xml方式(此处建议后者,因为更简单)

    3. 在DAO中注入sessionFactory

    4. 在Service中注入DAO

    5. 写DAOService的实现

    viii. 写测试

    c) 整合Struts2

    i. 结合点:Struts2ActionSpring产生

    ii. 步骤:

    1. 修改web.xml加入 strutsfilter

    如下:

    <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>

    2. 再加入springlistener,这样的话,webapp一旦启动,spring容器就初始化了

    如下:

    <!-- 指定由spring初始化加载xml配置文件 springstruts结合必备 -->

    <listener>

    <listener-class>

    org.springframework.web.context.ContextLoaderListener

    <!-- 默认寻找xml路径:WEB-INF/applicationContext.xml -->

    </listener-class>

    </listener>

     

    <!--整个应用的参数 服务启动时读取

    可指定spring初始化文件路径位置 -->

    <context-param>

    <param-name>contextConfigLocation</param-name>

    <param-value>

    classpath*:spring/*applicationContext.xml

    </param-value>

    </context-param>

    3. 规划strutsactionjsp展现

    4. 加入struts.xml

    a) 修改配置,由spring替代struts产生Action对象

    5. 修改action配置

    a) 把类名改为bean对象的名称,这个时候就可以使用首字母小写了

    b) @Scope(prototype)不要忘记

    iii. struts的读常量:

    1. struts-default.xml 

    2. struts-plugin.xml

    3. struts.xml

    4. struts.properties

    5. web.xml

    iv. 中文问题:

    1. Struts2.1.8已经修正,只需要改i18n.encoding = gbk

    2. 使用springcharacterencoding

    :

    <!-- 过滤器相关配置 ======== 字符编码过滤======== -->

    <filter>

    <filter-name>CharacterEncodingFilter</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>

    3. 需要严格注意filter的顺序

    4. 需要加到Struts2filter前面

    v. LazyInitializationException

    1. OpenSessionInViewFilter

    2. 需要严格顺序问题

    3. 需要加到struts2filter前面

    1

    @Autowired @Resource 都可以用来装配bean.  都可以写在属性定义上,或写在set方法上

    @Autowired (srping提供的默认按类型装配 

    @Resource ( j2ee提供的 默认按名称装配,当找不到(不写name属性)名称匹配的bean再按类型装配

    可以通过@Resource(name="beanName") 指定被注入的bean的名称要是指定了name属性就用 字段名 去做name属性值,一般不用写name属性

    @Resource(name="beanName")指定了name属性,按名称注入但没找到bean, 就不会再按类型装配了.

    @Autowired @Resource可作用在属性定义上,  就不用写set方法了(此方法不提倡);

     

     

    2

    a.

    Action类前加@Component,Action可由spring来管理,例子如下:

    Action中写:

    @Component("u") //spring管理注解

    @Scope("prototype") //多态

    public class UserAction extends ActionSupport implements ModelDriven{

    //内部属性需要有get/set方法 且需要set方法前加@Resource@Autowired

    }

     

    Struts2配置文件中写

    <action name="u" class="u"> 

     

    Jsp

    <form method="post" action="u.do" >

     

    b.

    Action中也可不加@ComponentActionstruts2-spring-plugin管理。此时,如果Action中定义的属性有set方法 则@Autowired @Resource也可不写,但是如果没有set方法,则需要在属性前加上@Autowired @Resource才能生效。

     

     

    3

    Hibernate如果使用load来查询数据,例如:

    Service中:

    public User loadById(int id) {

    return this.userDao.loadById(id);

    }

    DAO中:

    public User loadById(int id) {

    return (User)this.hibernateTemplate.load(User.class, id);

    }

    此时,session(应该说的是Hibernatesession)在事物结束(通常是service调用完)后自动关闭。由于使用的是load获取数据,在jsp页面申请取得数据时才真正的执行sql,而此时session已经关闭,故报错。

    Session关闭解决方法:

    web.xml中增加filter—openSessionInView,用于延长sessionjsp调用完后再关闭

    如下所示:

    注意:filter –openSessionInView 一定要在 filterstruts2之前调用

      Filter顺序先进后出!

    <filter>

    <filter-name>OpenSessionInViewFilter</filter-name>

    <filter-class>

    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter

    </filter-class>

    <init-param>

    <param-name>sessionFactoryBeanName</param-name>

    <param-value>sf</param-value>(此处默认指定的sessionFactory应为” sessionFactory” 默认可省略此行 如果shring配置文件中配置的sessionFactorysf 则此处需要写sf  一般用不到)

    </init-param>

    </filter>

    <filter-mapping>

    <filter-name> OpenSessionInViewFilter </filter-name>

    <url-pattern>/*</url-pattern>

    </filter-mapping>

    <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>

     

     

     

     

     

     

     

    1、导入29个JAR包

    JAR包名称

    作用

    Struts2.1.67个)

    struts2-core-2.1.6.jar

    struts2开发的核心类库

    freemarker-2.3.13.jar

    struts2UI标签的模板使用freemarker编写

    commons-logging-1.0.4.jar

    ASF出的日志包,支持Log4J和JDK的日志记录

    ognl-2.6.11.jar

    对象图导航语言,通过它来读写对象属性

    xwork-2.1.2.jar

    xwork类库,struts2在其上进行构建

    commons-fileupload-1.2.1.jar

    文件上传组件,2.1.6版本后必须加入此jar

    commons-io-1.3.2.jar

    以后文件上传下载需要

    Hibernate3.3.213个)

     

    hibernate3.jar

    hibernate3开发的核心类库

    antlr-2.7.6.jar

    解析HQL

    commons-collections-3.1.jar

    集合框架

    dom4j-1.6.1.jar

    解析xml

    javassist-3.9.0.GA.jar

    jta-1.1.jar

    junit-4.8.1.jar

    Junit test 包

    ejb3-persistence.jar

    @Entity

    Hibernate-annotations.jar

    Hibernate-commons-annotations.jar

    log4j-1.2.15.jar

    是log4j实现类

    slf4j-api-1.5.8.jar

    标准接口

    slf4j-log4j12-1.5.8.jar

    是slf4j转换log4j的中间接口

    Spring 2.5.68个)

    spring.jar

    Spring核心文件

    common-annotations.jar

    IOC支持, 例如@resource

    aspectjrt.jar

    AOP支持:aspectj运行时候需要的

    aspectjweaver.jar  

    AOP支持:织入

    cglib-nodep-2.1_3.jar

    动态生成字节码

    Commons-dbcp.jar 

    数据源       

    commons-po ol.jar

    数据源                           

    struts2-spring-plugin-2.1.6.jar

    Struts2和Spring结合所需包

    commons-logging-1.0.4.jar

    Struts2加入了就不需要导入

    log4j-1.2.15.jar

    Hibernate加入了就不需要导入

    数据库包(1个)

    mysql-connector-java-3.1.10-bin.jar

    MySql的驱动程序

     

     2、导入框架的配置文件

    SRC目录下的配置文件

    log4j.properties

    log4j的配置文件,放到SRC根目录下

    hibernate.cfg.xml

    Hibernate的配置文件

    beans.xml

    Spring的配置文件

    struts.xml

    Struts的配置文件

     

    WEB-INF下配置文件

    web.xml

    Struts2Spring的结合配置

      PS:如果需要使用JSTL标签需要导入2个包

        jstl.jar

        standard.jar

    3、建立对应的package和对应的接口与类框架

    hibernate.cfg.xml

    Xml代码

    <?xml version='1.0' encoding='GBK'?>     

    1. <!DOCTYPE hibernate-configuration PUBLIC      

    2.         "-//Hibernate/Hibernate Configuration DTD 3.0//EN"      

    3.         "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">     

    4. <hibernate-configuration>     

    5.      

    6.     <session-factory>     

    7.              

    8.         <!-- MySQL数据库连接设置.端口号不用改。只需修改XXXX-->     

    9.         <property name="connection.driver_class">com.mysql.jdbc.Driver</property>     

    10.         <property name="connection.url">jdbc:mysql://localhost:3306/ssh</property>     

    11.         <property name="connection.username">root</property>     

    12.         <property name="connection.password">lee</property>     

    13.      

    14.         <!-- 一般不用HIBERNATE的连接池       

    15.         <property name="connection.pool_size">1</property>     

    16.         -->     

    17.      

    18.         <!--  指定用哪种数据库语言,查文档搜索dialect -->     

    19.         <property name="dialect">org.hibernate.dialect.MySQLDialect</property>     

    20.         <!--<property name="dialect">org.hibernate.dialect.SQLServerDialect</property> -->     

    21.      

    22.         <!-- 当前SESSION运行环境的上下文getCurrentSession对应的配置-thread线程。JTA是分布式管理,例如多个数据库-->     

    23.         <property name="current_session_context_class">thread</property>     

    24.      

    25.         <!-- Disable the second-level cache  -->     

    26.         <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>     

    27.      

    28.         <!-- 打印自动生成的SQL语句-->     

    29.         <property name="show_sql">true</property>     

    30.               

    31.         <!-- 格式化SQL语句      

    32.         <property name="format_sql">true</property>-->     

    33.      

    34.         <!-- 如果不存在表,自动在数据库里生成,常用的是create,update-->     

    35.         <property name="hbm2ddl.auto">update</property>     

    36.      

    37.         <!-- 定义需要映射的路径      

    38.         <mapping class="ssh.model.User"/>     

    39.         -->     

    40.               

    41.     </session-factory>     

    42. </hibernate-configuration>   

    beans:xml

    Xml代码  

    1. <?xml version="1.0" encoding="GBK"?>     

    2. <beans xmlns="http://www.springframework.org/schema/beans"     

    3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     

    4.     xmlns:context="http://www.springframework.org/schema/context"     

    5.     xmlns:aop="http://www.springframework.org/schema/aop"     

    6.     xmlns:tx="http://www.springframework.org/schema/tx"     

    7.     xsi:schemaLocation="http://www.springframework.org/schema/beans      

    8.            http://www.springframework.org/schema/beans/spring-beans-2.5.xsd      

    9.            http://www.springframework.org/schema/context      

    10.            http://www.springframework.org/schema/context/spring-context-2.5.xsd      

    11.            http://www.springframework.org/schema/aop      

    12.            http://www.springframework.org/schema/aop/spring-aop-2.5.xsd      

    13.            http://www.springframework.org/schema/tx      

    14.            http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">        

    15.     <!--使用Annotation-->     

    16.     <context:annotation-config />     

    17.           

    18.     <!--自动扫描com.bjsxt包下所有写了@Component的类注入进来-->     

    19.     <context:component-scan base-package="ssh" />     

    20.           

    21.     <!--AOP:扫描上面定义自动扫描的路径com.bjsxt目录下的文件,就可以用@Aspect定义切入类-->     

    22.     <aop:aspectj-autoproxy />     

    23.      

    24.      

    25.     <!--==========================定义数据源==========================-->     

    26.     <bean id="dataSource"    class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">     

    27.     <property name="driverClassName" value="com.mysql.jdbc.Driver" />     

    28.     <property name="url" value="jdbc:mysql://localhost:3306/ssh" />     

    29.     <property name="username" value="root" />     

    30.     <property name="password" value="lee" />     

    31.     </bean>     

    32.      

    33.      

    34.     <!--=======================定义sessionFactory====================-->     

    35.     <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">     

    36.         <property name="dataSource" ref="dataSource" />     

    37.      

    38.          <!-- 将参数名称设为packagesToScan 可定义扫描目标包下所有实体类,告诉sessionFactory哪些类被Entity和注解了 -->     

    39.          <property name="packagesToScan">     

    40.             <list>     

    41.                 <value>ssh.model</value>     

    42.             </list>     

    43.          </property>     

    44.      

    45.         <!--直接导入Hibernate的配置文件。这样才能自动建立数据库表和显示DDL语句。如果上面的配置只能先手动建立数据表然后更新。不能自动创建表-->     

    46.         <property name="configLocation" value="classpath:hibernate.cfg.xml"/>     

    47.     </bean>     

    48.           

    49.     <!--====================定义Hibernate事务管理器===================-->     

    50.     <bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">     

    51.         <property name="sessionFactory" ref="sessionFactory" />     

    52.     </bean>     

    53.           

    54.     <!--<aop:advisor 是定义事务的建议,pointcut-ref是上面pointcut的ID,advice-ref是单独的advice,是下面定义的 <tx:advice id="txAdvice" -->     

    55.     <aop:config>     

    56.         <aop:pointcut id="myServiceMethod" expression="execution(public * ssh.service..*.*(..))"  />     

    57.         <aop:advisor pointcut-ref="myServiceMethod" advice-ref="txAdvice"/>     

    58.     </aop:config>     

    59.           

    60.     <!--定义建议(事务),供<aop:advisor的advice-ref引用,transaction-manager=" txManager "引用的是上面定义的事务管理器<bean id="txManager"。   propagation="REQUIRED"可以省略,默认是这个-->     

    61.     <tx:advice id="txAdvice" transaction-manager="txManager">     

    62.         <tx:attributes>     

    63.             <tx:method name="add*" propagation="REQUIRED"/>     

    64.             <!--    

    65.             <tx:method name="exists" read-only="true" />    

    66.             -->     

    67.         </tx:attributes>     

    68.     </tx:advice>     

    69.      

    70.      

    71.     <!--=========================定义HibernateTemplate===================-->     

    72.     <!--定义后在DAO里注入HibernateTemplate(private HibernateTemplate hibernateTemplate;在其Set方法上加@Resource注入),hibernateTemplate里面直接由save、update、delete、load等方法,可以直接hibernateTemplate.save(testUser);-->     

    73.      

    74.     <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">     

    75.         <property name="sessionFactory" ref="sessionFactory"></property>     

    76.     </bean>     

    77.      

    78. </beans>  

    struts.xml

    Xml代码  

    1. <?xml version="1.0" encoding="GBK" ?>     

    2. <!DOCTYPE struts PUBLIC      

    3.     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"      

    4.     "http://struts.apache.org/dtds/struts-2.0.dtd">     

    5.      

    6. <struts>     

    7.      <constant name="struts.devMode" value="true" />                        

    8.      <package name="default" namespace="/" extends="struts-default">  

    9.         <action name="index" class="mstx.action.UserAction">     

    10.             <result name="success">/index.jsp</result>                        

    11.         </action>     

    12.         <action name="user" class="mstx.action.UserAction" method="save">     

    13.             <result name="success">/success.jsp</result>                         

    14.         </action>     

    15.               

    16.     </package>     

    17.      

    18. </struts>    

    <?xml version="1.0" encoding="GBK" ?>  

    <!DOCTYPE struts PUBLIC   

        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"   

        "http://struts.apache.org/dtds/struts-2.0.dtd">  

      

    <struts>  

         <constant name="struts.devMode" value="true" />                     

         <package name="default" namespace="/" extends="struts-default">

            <action name="index" class="mstx.action.UserAction">  

                <result name="success">/index.jsp</result>                     

            </action>  

            <action name="user" class="mstx.action.UserAction" method="save">  

                <result name="success">/success.jsp</result>                      

            </action>  

               

        </package>  

      

    </struts>  

    web.xml

    Xml代码  

    1. <?xml version="1.0" encoding="UTF-8"?>      

    2. <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"     

    3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     

    4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee       

    5.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">      

    6.     <welcome-file-list>      

    7.         <welcome-file>index.jsp</welcome-file>      

    8.     </welcome-file-list>      

    9.      

    10.     <listener>      

    11.         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>      

    12.         <!-- default: /WEB-INF/applicationContext.xml -->      

    13.     </listener>      

    14.      

    15.     <context-param>      

    16.         <param-name>contextConfigLocation</param-name>      

    17.         <!-- <param-value>/WEB-INF/applicationContext-*.xml,classpath*:applicationContext-*.xml</param-value>  -->      

    18.         <param-value>classpath:beans.xml</param-value>      

    19.     </context-param>      

    20.           

    21.           

    22.     <!--中文问题      

    23.         1.  Struts2.1.8已经修正,只需要改Struts.xmli18n.encoding = gbk      

    24.         2.  使用springcharacterencoding      

    25.     -->      

    26.     <filter>      

    27.         <filter-name>encodingFilter</filter-name>      

    28.         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>      

    29.         <init-param>      

    30.             <param-name>encoding</param-name>      

    31.             <param-value>GBK</param-value>      

    32.         </init-param>      

    33.     </filter>      

    34.           

    35.     <filter-mapping>      

    36.         <filter-name>encodingFilter</filter-name>      

    37.         <url-pattern>/*</url-pattern>      

    38.     </filter-mapping>      

    39.      

    40.      

    41.     <!--openSessionInView      

    42.         此时,session(应该说的是Hibernatesession)在事物结束(通常是service调用完)后自动关闭。由于使用的是load获取数据,在jsp页面申请取得数据时才真正的执行sql,而此时session已经关闭,故报错。      

    43.         Session关闭解决方法:      

    44.         web.xml中增加filter—openSessionInView,用于延长sessionjsp调用完后再关闭      

    45.      

    46.     -->      

    47.     <filter>      

    48.         <filter-name>openSessionInView</filter-name>      

    49.         <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>      

    50.     </filter>      

    51.           

    52.     <filter-mapping>      

    53.         <filter-name>openSessionInView</filter-name>      

    54.         <url-pattern>/*</url-pattern>      

    55.     </filter-mapping>      

    56.           

    57.     <filter>      

    58.         <filter-name>struts2</filter-name>      

    59.         <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>      

    60.     </filter>      

    61.      

    62.     <filter-mapping>      

    63.         <filter-name>struts2</filter-name>      

    64.         <url-pattern>/*</url-pattern>      

    65.     </filter-mapping>      

    66.           

    67. </web-app>   

    <?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">   

        <welcome-file-list>   

            <welcome-file>index.jsp</welcome-file>   

        </welcome-file-list>   

      

        <listener>   

            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>   

            <!-- default: /WEB-INF/applicationContext.xml -->   

        </listener>   

      

        <context-param>   

            <param-name>contextConfigLocation</param-name>   

            <!-- <param-value>/WEB-INF/applicationContext-*.xml,classpath*:applicationContext-*.xml</param-value>  -->   

            <param-value>classpath:beans.xml</param-value>   

        </context-param>   

           

           

        <!--中文问题   

            1.  Struts2.1.8已经修正,只需要改Struts.xml的i18n.encoding = gbk   

            2.  使用spring的characterencoding   

        -->   

        <filter>   

            <filter-name>encodingFilter</filter-name>   

            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>   

            <init-param>   

                <param-name>encoding</param-name>   

                <param-value>GBK</param-value>   

            </init-param>   

        </filter>   

           

        <filter-mapping>   

            <filter-name>encodingFilter</filter-name>   

            <url-pattern>/*</url-pattern>   

        </filter-mapping>   

      

      

        <!--openSessionInView   

            此时,session(应该说的是Hibernate的session)在事物结束(通常是service调用完)后自动关闭。由于使用的是load获取数据,在jsp页面申请取得数据时才真正的执行sql,而此时session已经关闭,故报错。   

            Session关闭解决方法:   

            在web.xml中增加filter—openSessionInView,用于延长session在jsp调用完后再关闭   

      

        -->   

        <filter>   

            <filter-name>openSessionInView</filter-name>   

            <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>   

        </filter>   

           

        <filter-mapping>   

            <filter-name>openSessionInView</filter-name>   

            <url-pattern>/*</url-pattern>   

        </filter-mapping>   

           

        <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>   

           

    </web-app> 

      

    4、建立实体类,并加入Hibernate的注解

      1)在实体类上加相应注解@Entity @Id

      2)在字段属性的get方法上加--@Column(name = "表字段名")

    User.java

    5、定义工具类

    1)定义查询返回结果

    QueryResult.java

    Java代码  

    1. package ssh.utils;   

    2.   

    3. import java.util.List;   

    4.   

    5. /*  

    6.  * 定义查询返回的结果,泛型定义在类上  

    7.  */  

    8. public class QueryResult<T> {   

    9.     private List<T> resultlist;       //记录查询的结果   

    10.     private long totalrecord;       //记录查询得到的总条数   

    11.        

    12.     public List<T> getResultlist() {   

    13.         return resultlist;   

    14.     }   

    15.     public void setResultlist(List<T> resultlist) {   

    16.         this.resultlist = resultlist;   

    17.     }   

    18.     public long getTotalrecord() {   

    19.         return totalrecord;   

    20.     }   

    21.     public void setTotalrecord(long totalrecord) {   

    22.         this.totalrecord = totalrecord;   

    23.     }   

    24. }  

    package ssh.utils;

    import java.util.List;

    /*

     * 定义查询返回的结果,泛型定义在类上

     */

    public class QueryResult<T> {

    private List<T> resultlist; //记录查询的结果

    private long totalrecord; //记录查询得到的总条数

    public List<T> getResultlist() {

    return resultlist;

    }

    public void setResultlist(List<T> resultlist) {

    this.resultlist = resultlist;

    }

    public long getTotalrecord() {

    return totalrecord;

    }

    public void setTotalrecord(long totalrecord) {

    this.totalrecord = totalrecord;

    }

    }

      

    2)定义分页工具类

    PageView.java

    Java代码  

    1. package ssh.utils;   

    2.   

    3. import java.util.List;   

    4.   

    5. /**  

    6.  *  Action里的调用方法  

    7.     //这里必须要构造新对象,不然刚打开没有currentPage参数传递过来,如果不新建也行,第一次打开必须传递currentPage参数过来  

    8.     private PageView<T>pageView=new PageView<T>();    

    9.       

    10.     public PageView<T> getPageView() {  

    11.         return pageView;  

    12.     }  

    13.  

    14.     public void setPageView(PageView<T> pageView) {  

    15.         this.pageView = pageView;  

    16.     }  

    17.     int maxresult=1;                  

    18.     int firstindex=(pageView.getCurrentPage()-1)*maxresult;  

    19.     QueryResult<T> Service.getScrollData(firstindex,maxresult, null, null, null);  

    20.     pageView.setQueryResult(maxresult,qr);  

    21.     request.put("pageView", pageView);  

    22.  */  

    23.   

    24. public class PageView<T> {   

    25.     /** 分页数据 **/  

    26.     private List<T> records;   

    27.   

    28.     /** 页码开始索引 ,例如显示第1 2 3 4 5 6 7 8 9 ,开始索引为1 **/  

    29.     private long startIndex;   

    30.   

    31.     /** 页码结束索引 ,例如显示第1 2 3 4 5 6 7 8 9 ,结束索引为9 **/  

    32.     private long endIndex;   

    33.   

    34.     /** 总页数 ,没有0页,所以设置默认值为1 **/  

    35.     private long totalPage = 1;   

    36.   

    37.     /** 每页显示记录数 **/  

    38.     private int maxResult = 10;   

    39.   

    40.     /** 当前页 **/  

    41.     private int currentPage = 1;   

    42.   

    43.     /** 总记录数 **/  

    44.     private long totalRecord;   

    45.   

    46.     /** 工具条上显示的页码数量 **/  

    47.     private int pageBarSize = 8;   

    48.   

    49.        

    50.     // 这只方法触发记录查询结果和总条数   

    51.     public void setQueryResult(int maxResult,QueryResult<T> qr) {   

    52.         this.maxResult = maxResult;   

    53.         this.records = qr.getResultlist();   

    54.         this.totalRecord = qr.getTotalrecord();   

    55.         this.totalPage = this.totalRecord % this.maxResult == 0 ? this.totalRecord/ this.maxResult : this.totalRecord / this.maxResult + 1;   

    56.            

    57.         /*****************************************************/  

    58.         this.startIndex = currentPage - (pageBarSize % 2 == 0 ? pageBarSize / 2 - 1 : pageBarSize / 2);   

    59.         this.endIndex = currentPage + pageBarSize / 2;   

    60.   

    61.         if (startIndex < 1) {   

    62.             startIndex = 1;   

    63.             if (totalPage >= pageBarSize)   

    64.                 endIndex = pageBarSize;   

    65.             else  

    66.                 endIndex = totalPage;   

    67.         }   

    68.         if (endIndex > totalPage) {   

    69.             endIndex = totalPage;   

    70.             if ((endIndex - pageBarSize) > 0)   

    71.                 startIndex = endIndex - pageBarSize +1; //最后一页显示多小条页   

    72.             else  

    73.                 startIndex = 1;   

    74.         }   

    75.     }   

    76.   

    77.     public List<T> getRecords() {   

    78.         return records;   

    79.     }   

    80.   

    81.     public void setRecords(List<T> records) {   

    82.         this.records = records;   

    83.     }   

    84.   

    85.     public long getStartIndex() {   

    86.         return startIndex;   

    87.     }   

    88.   

    89.     public void setStartIndex(long startIndex) {   

    90.         this.startIndex = startIndex;   

    91.     }   

    92.   

    93.     public long getEndIndex() {   

    94.         return endIndex;   

    95.     }   

    96.   

    97.     public void setEndIndex(long endIndex) {   

    98.         this.endIndex = endIndex;   

    99.     }   

    100.   

    101.     public long getTotalPage() {   

    102.         return totalPage;   

    103.     }   

    104.   

    105.     public void setTotalPage(long totalPage) {   

    106.         this.totalPage = totalPage;   

    107.     }   

    108.   

    109.     public int getMaxResult() {   

    110.         return maxResult;   

    111.     }   

    112.   

    113.     public void setMaxResult(int maxResult) {   

    114.         this.maxResult = maxResult;   

    115.     }   

    116.   

    117.     public int getCurrentPage() {   

    118.         return currentPage;   

    119.     }   

    120.   

    121.     public void setCurrentPage(int currentPage) {   

    122.         this.currentPage = currentPage<1?1:currentPage;  //如果当前页为0,则显示第一页   

    123.     }   

    124.   

    125.     public long getTotalRecord() {   

    126.         return totalRecord;   

    127.     }   

    128.   

    129.     public void setTotalRecord(long totalRecord) {   

    130.         this.totalRecord = totalRecord;   

    131.     }   

    132.   

    133.     public int getPageBarSize() {   

    134.         return pageBarSize;   

    135.     }   

    136.   

    137.     public void setPageBarSize(int pageBarSize) {   

    138.         this.pageBarSize = pageBarSize;   

    139.     }   

    140. }  

     

  • 相关阅读:
    MapReduce1.x与MapReduce2.x差异
    刷题60—排序数组
    刷题59— 圆圈中最后剩下的数字
    刷题58—地图分析
    刷题57—单词的压缩编码
    刷题56—卡牌分组
    刷题55—车的可用捕获量
    刷题54—三维形体的表面积
    刷题53—按摩师
    刷题52—链表的中间结点
  • 原文地址:https://www.cnblogs.com/robbychan/p/3786544.html
Copyright © 2020-2023  润新知