简介:1、Aop编程。2、AspectJ基于xml文件。3、AspectJ基于注解。 4、JdbcTemplate。 5、配置properties文件

1       AOP

1.1   AOP介绍

1.1.1   什么是AOP

l    在软件业,AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行

  期动态代理实现程序功能的统一维护的一种技术。AOP是OOP(面向对象编程)的延续,是软件开发中的

  一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑

  的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开

  发的效率。

l    AOP采取横向抽取机制,取代了传统纵向继承体系重复性代码

l    经典应用:事务管理、性能监视、安全检查、缓存 、日志等

l    Spring AOP使用纯Java实现,不需要专门的编译过程和类加载器,在运行期通过代理方式向目标类织入

  增强代码

l    AspectJ是一个基于Java语言的AOP框架,Spring2.0开始,Spring AOP引入对Aspect的支持,AspectJ扩

  展了Java语言,提供了一个专门的编译器,在编译时提供横向代码的织入

1.1.2   AOP实现原理

l    aop底层将采用代理机制进行实现。

l    接口 + 实现类 :spring采用 jdk 的动态代理Proxy。

l    实现类:spring 采用 cglib字节码增强。

1.1.3   AOP术语【掌握】

  1.target:目标类,需要被代理的类。例如:UserService

  2.Joinpoint(连接点):所谓连接点是指那些可能被拦截到的方法。例如:所有的方法

  3.PointCut 切入点:已经被增强的连接点。例如:addUser()

  4.advice 通知/增强,增强代码。例如:after、before

  5. Weaving(织入):是指把增强advice应用到目标对象target来创建新的代理对象proxy的过程.

  6.proxy 代理类

  7. Aspect(切面): 是切入点pointcut和通知advice的结合

    一个线是一个特殊的面。

   一个切入点和一个通知,组成成一个特殊的面。

1.2   手动方式

1.2.1   JDK动态代理

l  JDK动态代理 对“装饰者”设计模式 简化。使用前提:必须有接口

1.目标类:接口 + 实现类

2.切面类:用于存通知 MyAspect

3.工厂类:编写工厂生成代理(后面由spring完成)

4.测试

1.2.1.1         目标类

public interface UserService {

   public void addUser();

   public void updateUser();

   public void deleteUser();
}

1.2.1.2         切面类

public class MyAspect {

   public void before(){

      System.out.println("鸡首");
} public void after(){ System.out.println("牛后");
}
}

1.2.1.3         工厂 (动态代理的经典实现)

public class MyBeanFactory {

   public static UserService createService(){

      //1 目标类

      final UserService userService = new UserServiceImpl();

      //2切面类

      final MyAspect myAspect = new MyAspect();

      /* 3 代理类:将目标类(切入点)和 切面类(通知) 结合 --> 切面

       * Proxy.newProxyInstance

       *    参数1:loader ,类加载器,动态代理类 运行时创建,任何类都需要类加载器将其加载到内存。

       *       一般情况:当前类.class.getClassLoader();

       *              目标类实例.getClass().get...

       *    参数2:Class[] interfaces 代理类需要实现的所有接口

       *        方式1:目标类实例.getClass().getInterfaces()  ;注意:只能获得自己接口,不能获得父元素接口

       *        方式2:new Class[]{UserService.class}  

       *        例如:jdbc 驱动  --> DriverManager  获得接口 Connection

       *    参数3:InvocationHandler  处理类,接口,必须进行实现类,一般采用匿名内部

       *        提供 invoke 方法,代理类的每一个方法执行时,都将调用一次invoke

       *           参数31:Object proxy :代理对象

       *           参数32:Method method : 代理对象当前执行的方法的描述对象(反射)

       *              执行方法名:method.getName()

       *              执行方法:method.invoke(对象,实际参数)

       *           参数33:Object[] args :方法实际参数

       */

      UserService proxService = (UserService)Proxy.newProxyInstance(

                         MyBeanFactory.class.getClassLoader(),

                         userService.getClass().getInterfaces(),

                         new InvocationHandler() {    

                            @Override

                            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

                               //前执行

                               myAspect.before();

                               //执行目标类的方法

                               Object obj = method.invoke(userService, args);

                               //后执行

                               myAspect.after();
return obj;
} });
return proxService; }
}

1.2.1.4         测试

   @Test
public void demo01(){ UserService userService = MyBeanFactory.createService(); userService.addUser(); userService.updateUser(); userService.deleteUser();
}

1.2.2   CGLIB字节码增强

l    没有接口,只有实现类。

l    采用字节码增强框架 cglib,在运行时 创建目标类的子类,从而对目标类进行增强。

l    导入jar包:

    自己导包(了解):

    核心:hibernate-distribution-3.6.10.Final\lib\bytecode\cglib\cglib-2.2.jar

  依赖:struts-2.3.15.3\apps\struts2-blank\WEB-INF\lib\asm-3.3.jar

  spring-core..jar 已经整合以上两个内容

1.2.2.1         工厂类

public class MyBeanFactory {

   public static UserServiceImpl createService(){

      //1 目标类

      final UserServiceImpl userService = new UserServiceImpl();

      //2切面类

      final MyAspect myAspect = new MyAspect();

      // 3.代理类 ,采用cglib,底层创建目标类的子类

      //3.1 核心类

      Enhancer enhancer = new Enhancer();

      //3.2 确定父类

      enhancer.setSuperclass(userService.getClass());

      /* 3.3 设置回调函数 , MethodInterceptor接口 等效 jdk InvocationHandler接口

       * intercept() 等效 jdk  invoke()

       *    参数1、参数2、参数3:以invoke一样

       *    参数4:methodProxy 方法的代理
*/
enhancer.setCallback(new MethodInterceptor(){ @Override
public Object intercept(Object proxy, Method method, Object[] args, MethodProxy methodProxy) throws Throwable { //前
myAspect.before(); //执行目标类的方法 Object obj = method.invoke(userService, args); // * 执行代理类的父类 ,执行目标类 (目标类和代理类 父子关系) methodProxy.invokeSuper(proxy, args); //后
myAspect.after(); return obj; } }); //3.4 创建代理 UserServiceImpl proxService = (UserServiceImpl) enhancer.create(); return proxService; }
}

1.3   AOP联盟通知类型

l  AOP联盟为通知Advice定义了org.aopalliance.aop.Advice

l  Spring按照通知Advice在目标类方法的连接点位置,可以分为5类

  • 前置通知 org.springframework.aop.MethodBeforeAdvice

    • 在目标方法执行前实施增强
  • 后置通知 org.springframework.aop.AfterReturningAdvice
    • 在目标方法执行后实施增强
  • 环绕通知 org.aopalliance.intercept.MethodInterceptor
    • 在目标方法执行前后实施增强
  • 异常抛出通知 org.springframework.aop.ThrowsAdvice
    • 在方法抛出异常后实施增强
  • 引介通知 org.springframework.aop.IntroductionInterceptor
    • 在目标类中添加一些新的方法和属性

环绕通知,必须手动执行目标方法

try{

//前置通知

//执行目标方法

//后置通知

} catch(){

//抛出异常通知

}

1.4   spring编写代理:半自动

l  让spring 创建代理对象,从spring容器中手动的获取代理对象。

l  导入jar包:

核心:4+1

AOP:AOP联盟(规范)、spring-aop (实现)

1.4.1   目标类

public interface UserService {

   public void addUser();

   public void updateUser();

   public void deleteUser();
}

1.4.2   切面类

/**

 * 切面类中确定通知,需要实现不同接口,接口就是规范,从而就确定方法名称。

 * * 采用“环绕通知” MethodInterceptor
*/ public class MyAspect implements MethodInterceptor { @Override public Object invoke(MethodInvocation mi) throws Throwable { System.out.println("前3"); //手动执行目标方法 Object obj = mi.proceed();
System.out.println("后3"); return obj; } }

1.4.3   spring配置

   <!-- 1 创建目标类 -->

    <bean id="userServiceId" class="com.itheima.b_factory_bean.UserServiceImpl"></bean>

    <!-- 2 创建切面类 -->

    <bean id="myAspectId" class="com.itheima.b_factory_bean.MyAspect"></bean>

    <!-- 3 创建代理类

        * 使用工厂bean FactoryBean ,底层调用 getObject() 返回特殊bean

        * ProxyFactoryBean 用于创建代理工厂bean,生成特殊代理对象

            interfaces : 确定接口们

                通过<array>可以设置多个值

                只有一个值时,value=""

            target : 确定目标类

            interceptorNames : 通知 切面类的名称,类型String[],如果设置一个值 value=""

            optimize :强制使用cglib

                <property name="optimize" value="true"></property>

        底层机制

            如果目标类有接口,采用jdk动态代理

            如果没有接口,采用cglib 字节码增强

            如果声明 optimize = true ,无论是否有接口,都采用cglib
--> <bean id="proxyServiceId" class="org.springframework.aop.framework.ProxyFactoryBean"> <property name="interfaces" value="com.itheima.b_factory_bean.UserService"></property> <property name="target" ref="userServiceId"></property> <property name="interceptorNames" value="myAspectId"></property> </bean>

1.4.4   测试

@Test

public void demo01(){

String xmlPath = "com/itheima/b_factory_bean/beans.xml";

ApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlPath);

//获得代理类(如果想要使用动态代理创建代理对象,那么在此处就需要使用接口类型接收

UserService userService = (UserService) applicationContext.getBean("proxyServiceId");

userService.addUser();

userService.updateUser();

userService.deleteUser();

}

1.5   spring aop编程:全自动【掌握】

l  从spring容器获得目标类,如果配置aop,spring将自动生成代理。

l  要确定目标类,aspectj 切入点表达式,导入jar包

spring-framework-3.0.2.RELEASE-dependencies\org.aspectj\com.springsource.org.aspectj.weaver\1.6.8.RELEASE.jar

1.5.1   spring配置

<?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:aop="http://www.springframework.org/schema/aop"

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

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

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

                            http://www.springframework.org/schema/aop/spring-aop.xsd">

    <!-- 1 创建目标类 -->

    <bean id="userServiceId" class="com.itheima.c_spring_aop.UserServiceImpl"></bean>

    <!-- 2 创建切面类(通知) -->

    <bean id="myAspectId" class="com.itheima.c_spring_aop.MyAspect"></bean>

    <!-- 3 aop编程

        3.1 导入命名空间

        3.2 使用 <aop:config>进行配置

                proxy-target-class="true" 声明时使用cglib代理

            <aop:pointcut> 切入点 ,从目标对象获得具体方法

            <aop:advisor> 特殊的切面,只有一个通知 和 一个切入点

                advice-ref 通知引用

                pointcut-ref 切入点引用

        3.3 切入点表达式

            execution(* com.itheima.c_spring_aop.*.*(..))

            选择方法         返回值任意   包             类名任意   方法名任意   参数任意
--> <aop:config proxy-target-class="true"> <aop:pointcut expression="execution(* com.itheima.c_spring_aop.*.*(..))" id="myPointCut"/> <aop:advisor advice-ref="myAspectId" pointcut-ref="myPointCut"/> </aop:config> </beans>

1.5.2   测试

@Test

public void demo01(){

String xmlPath = "com/itheima/c_spring_aop/beans.xml";

ApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlPath);

//获得目标类

UserService userService = (UserService) applicationContext.getBean("userServiceId");

userService.addUser();

userService.updateUser();

userService.deleteUser();

}

2       AspectJ

2.1   介绍

l    AspectJ是一个基于Java语言的AOP框架

l    Spring2.0以后新增了对AspectJ切点表达式支持

l    @AspectJ 是AspectJ1.5新增功能,通过JDK5注解技术,允许直接在Bean类中定义切面

      新版本Spring框架,建议使用AspectJ方式来开发AOP

l    主要用途:自定义开发

2.2   切入点表达式【掌握】

1.execution()  用于描述方法 【掌握】

语法:execution(修饰符  返回值  包.类.方法名(参数) throws异常)

修饰符,一般省略

public            公共方法

*                   任意

返回值,不能省略

void               返回没有值

String            返回值字符串

*                   任意

包,[省略]

com.itheima.crm                  固定包

com.itheima.crm.*.service     crm包下面子包任意 (例如:com.itheima.crm.staff.service)

com.itheima.crm..                crm包下面的所有子包(含自己)

com.itheima.crm.*.service..   crm包下面任意子包,固定目录service,service目录任意包

类,[省略]

UserServiceImpl                  指定类

*Impl                                  以Impl结尾

User*                                  以User开头

*                                        任意

方法名,不能省略

addUser                               固定方法

add*                                          以add开头

*Do                                    以Do结尾

*                                        任意

(参数)

()                                        无参

(int)                                    一个整型

(int ,int)                              两个

(..)                                      参数任意

throws ,可省略,一般不写。

综合1

execution(* com.itheima.crm.*.service..*.*(..))

综合2

<aop:pointcut expression="execution(* com.itheima.*WithCommit.*(..)) ||

execution(* com.itheima.*Service.*(..))" id="myPointCut"/>

2.within:匹配包或子包中的方法(了解)

within(com.itheima.aop..*)

3.this:匹配实现接口的代理对象中的方法(了解)

this(com.itheima.aop.user.UserDAO)

4.target:匹配实现接口的目标对象中的方法(了解)

target(com.itheima.aop.user.UserDAO)

5.args:匹配参数格式符合标准的方法(了解)

args(int,int)

6.bean(id)  对指定的bean所有的方法(了解)

bean('userServiceId')

2.3   AspectJ 通知类型

l    aop联盟定义通知类型,具有特性接口,必须实现,从而确定方法名称。

l    aspectj 通知类型,只定义类型名称。以及方法格式。

l    个数:6种,知道5种,掌握1中。

    before:前置通知(应用:各种校验)

   在方法执行前执行,如果通知抛出异常,阻止方法运行

   afterReturning:后置通知(应用:常规数据处理)

     方法正常返回后执行,如果方法中抛出异常,通知无法执行

   必须在方法执行后才执行,所以可以获得方法的返回值。

    around:环绕通知(应用:十分强大,可以做任何事情)

    方法执行前后分别执行,可以阻止方法的执行

    必须手动执行目标方法

  afterThrowing:抛出异常通知(应用:包装异常信息)

    方法抛出异常后执行,如果方法没有抛出异常,无法执行

   after:最终通知(应用:清理现场)

    方法执行完毕后执行,无论方法中是否出现异常

环绕

try{

//前置:before

//手动执行目标方法

//后置:afterRetruning

} catch(){

//抛出异常 afterThrowing

} finally{

//最终 after

}

2.4   导入jar包

l  4个:

aop联盟规范

spring aop 实现

aspect 规范

spring aspect 实现

2.5   基于xml

1.目标类:接口 + 实现

2.切面类:编写多个通知,采用aspectj 通知名称任意(方法名任意)

3.aop编程,将通知应用到目标类

4.测试

2.5.1   切面类

/**

 * 切面类,含有多个通知

 */

public class MyAspect {

    public void myBefore(JoinPoint joinPoint){

        System.out.println("前置通知 : " + joinPoint.getSignature().getName());
} public void myAfterReturning(JoinPoint joinPoint,Object ret){ System.out.println("后置通知 : " + joinPoint.getSignature().getName() + " , -->" + ret);
} public Object myAround(ProceedingJoinPoint joinPoint) throws Throwable{ System.out.println("前"); //手动执行目标方法
Object obj = joinPoint.proceed(); System.out.println("后"); return obj;
} public void myAfterThrowing(JoinPoint joinPoint,Throwable e){ System.out.println("抛出异常通知 : " + e.getMessage());
} public void myAfter(JoinPoint joinPoint){ System.out.println("最终通知");
}
}

2.5.2   spring配置

<!-- 1 创建目标类 -->
<bean id="userServiceId" class="com.itheima.d_aspect.a_xml.UserServiceImpl"></bean>
<!-- 2 创建切面类(通知) -->
<bean id="myAspectId" class="com.itheima.d_aspect.a_xml.MyAspect"></bean>
<!-- 3 aop编程
<aop:aspect> 将切面类 声明“切面”,从而获得通知(方法)
ref 切面类引用
<aop:pointcut> 声明一个切入点,所有的通知都可以使用。
expression 切入点表达式
id 名称,用于其它通知引用
-->
<aop:config>
<aop:aspect ref="myAspectId">
<aop:pointcut expression="execution(* com.itheima.d_aspect.a_xml.UserServiceImpl.*(..))" id="myPointCut"/> <!-- 3.1 前置通知
<aop:before method="" pointcut="" pointcut-ref=""/>
method : 通知,及方法名
pointcut :切入点表达式,此表达式只能当前通知使用。
pointcut-ref : 切入点引用,可以与其他通知共享切入点。
通知方法格式:public void myBefore(JoinPoint joinPoint){
参数1:org.aspectj.lang.JoinPoint 用于描述连接点(目标方法),获得目标方法名等
例如:
<aop:before method="myBefore" pointcut-ref="myPointCut"/>
--> <!-- 3.2后置通知 ,目标方法后执行,获得返回值
<aop:after-returning method="" pointcut-ref="" returning=""/>
returning 通知方法第二个参数的名称
通知方法格式:public void myAfterReturning(JoinPoint joinPoint,Object ret){
参数1:连接点描述
参数2:类型Object,参数名 returning="ret" 配置的
例如:
<aop:after-returning method="myAfterReturning" pointcut-ref="myPointCut" returning="ret" />
--> <!-- 3.3 环绕通知
<aop:around method="" pointcut-ref=""/>
通知方法格式:public Object myAround(ProceedingJoinPoint joinPoint) throws Throwable{
返回值类型:Object
方法名:任意
参数:org.aspectj.lang.ProceedingJoinPoint
抛出异常
执行目标方法:Object obj = joinPoint.proceed();
例如:
<aop:around method="myAround" pointcut-ref="myPointCut"/>
-->
<!-- 3.4 抛出异常
<aop:after-throwing method="" pointcut-ref="" throwing=""/>
throwing :通知方法的第二个参数名称
通知方法格式:public void myAfterThrowing(JoinPoint joinPoint,Throwable e){
参数1:连接点描述对象
参数2:获得异常信息,类型Throwable ,参数名由throwing="e" 配置
例如:
<aop:after-throwing method="myAfterThrowing" pointcut-ref="myPointCut" throwing="e"/>
-->
<!-- 3.5 最终通知 -->
<aop:after method="myAfter" pointcut-ref="myPointCut"/> </aop:aspect>
</aop:config>

2.6   基于注解

2.6.1   替换bean

   <!-- 1 创建目标类 -->
<bean id="userServiceId" class="com.itheima.d_aspect.b_anno.UserServiceImpl"></bean>
<!-- 2 创建切面类(通知) -->
<bean id="myAspectId" class="com.itheima.d_aspect.b_anno.MyAspect"></bean>

l  注意:扫描

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

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

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

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

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

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

                            http://www.springframework.org/schema/context/spring-context.xsd">

   <!-- 1.扫描 注解类 -->

    <context:component-scan base-package="com.itheima.d_aspect.b_anno"></context:component-scan>

    <!-- 2.确定 aop注解生效 -->

    <aop:aspectj-autoproxy></aop:aspectj-autoproxy>

2.6.2   替换aop

l  必须进行aspectj 自动代理

  <!-- 2.确定 aop注解生效 -->

   <aop:aspectj-autoproxy></aop:aspectj-autoproxy>

l  声明切面

 <aop:aspect ref="myAspectId">

替换为:

l  替换前置通知

<aop:before method="myBefore" pointcut="execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))"/>

替换为

 //切入点当前有效

   @Before("execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))")

   public void myBefore(JoinPoint joinPoint){

      System.out.println("前置通知 : " + joinPoint.getSignature().getName());

   }

l  替换 公共切入点

<aop:pointcut expression="execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))" id="myPointCut"/>

替换为

//声明公共切入点

   @Pointcut("execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))")
private void myPointCut(){ }

l  替换后置

<aop:after-returning method="myAfterReturning" pointcut-ref="myPointCut" returning="ret" />

替换为

 @AfterReturning(value="myPointCut()" ,returning="ret")

    public void myAfterReturning(JoinPoint joinPoint,Object ret){

        System.out.println("后置通知 : " + joinPoint.getSignature().getName() + " , -->" + ret);

    }

l  替换环绕

<aop:around method="myAround" pointcut-ref="myPointCut"/>
@Around(value = "myPointCut()")

    public Object myAround(ProceedingJoinPoint joinPoint) throws Throwable{

        System.out.println("前");

        //手动执行目标方法

        Object obj = joinPoint.proceed();

        System.out.println("后");

        return obj;
}

l  替换抛出异常

<aop:after-throwing method="myAfterThrowing" pointcut="execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))" throwing="e"/>
@AfterThrowing(value="execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))" ,throwing="e")

    public void myAfterThrowing(JoinPoint joinPoint,Throwable e){

        System.out.println("抛出异常通知 : " + e.getMessage());

    }

2.6.3切面类

 /**

  * 切面类,含有多个通知

  */

 @Component

 @Aspect

 public class MyAspect {

     //切入点当前有效

 //  @Before("execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))")

     public void myBefore(JoinPoint joinPoint){

         System.out.println("前置通知 : " + joinPoint.getSignature().getName());

     }

     //声明公共切入点

     @Pointcut("execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))")

     private void myPointCut(){

     }

 //  @AfterReturning(value="myPointCut()" ,returning="ret")

     public void myAfterReturning(JoinPoint joinPoint,Object ret){

         System.out.println("后置通知 : " + joinPoint.getSignature().getName() + " , -->" + ret);

     }

 //  @Around(value = "myPointCut()")

     public Object myAround(ProceedingJoinPoint joinPoint) throws Throwable{

         System.out.println("前");

         //手动执行目标方法

         Object obj = joinPoint.proceed();

         System.out.println("后");

         return obj;

     }

 //  @AfterThrowing(value="execution(* com.itheima.d_aspect.b_anno.UserServiceImpl.*(..))" ,throwing="e")

     public void myAfterThrowing(JoinPoint joinPoint,Throwable e){

         System.out.println("抛出异常通知 : " + e.getMessage());

     }

     @After("myPointCut()")

     public void myAfter(JoinPoint joinPoint){

         System.out.println("最终通知");

     }

 }

Myaspect

2.6.4   spring配置

    <!-- 1.扫描 注解类 -->
<context:component-scan base-package="com.itheima.d_aspect.b_anno"></context:component-scan> <!-- 2.确定 aop注解生效 -->
<aop:aspectj-autoproxy></aop:aspectj-autoproxy>

2.6.5   aop注解总结

  @Aspect  声明切面,修饰切面类,从而获得 通知。

通知

@Before 前置

@AfterReturning 后置

@Around 环绕

@AfterThrowing 抛出异常

@After 最终

切入点

@PointCut ,修饰方法 private void xxx(){}  之后通过“方法名”获得切入点引用

  

3       JdbcTemplate

l  spring 提供用于操作JDBC工具类,类似:DBUtils。

l  依赖 连接池DataSource (数据源)

3.1   环境搭建

3.1.1   创建表

 create database ee19_spring_day02;

 use ee19_spring_day02;

 create table t_user(
id int primary key auto_increment,
username varchar(50),
password varchar(32)
);
insert into t_user(username,password) values('jack',''); insert into t_user(username,password) values('rose','');

3.1.2   导入jar包

3.1.3   javabean

 package com.itheima.domain;

 public class User {

    private Integer id;

    private String username;

    private String password;

3.2   使用api(了解)

public static void main(String[] args) {

        //1 创建数据源(连接池) dbcp

        BasicDataSource dataSource = new BasicDataSource();

        // * 基本4项

        dataSource.setDriverClassName("com.mysql.jdbc.Driver");

        dataSource.setUrl("jdbc:mysql://localhost:3306/ee19_spring_day02");

        dataSource.setUsername("root");

        dataSource.setPassword("1234");

        //2  创建模板

        JdbcTemplate jdbcTemplate = new JdbcTemplate();

        jdbcTemplate.setDataSource(dataSource);

        //3 通过api操作

        jdbcTemplate.update("insert into t_user(username,password) values(?,?);", "tom","998"); 

    }

3.3   配置DBCP

   <!-- 创建数据源 -->
<bean id="dataSourceId" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/ee19_spring_day02"></property>
<property name="username" value="root"></property>
<property name="password" value="1234"></property>
</bean>
<!-- 创建模板 ,需要注入数据源-->
<bean id="jdbcTemplateId" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSourceId"></property>
</bean> <!-- 配置dao注入模板 -->
<bean id="userDaoId" class="com.itheima.c_dbcp.UserDao">
<property name="jdbcTemplate" ref="jdbcTemplateId"></property>
</bean>

3.4   配置C3P0

  <!-- 创建数据源 c3p0-->
<bean id="dataSourceId" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/ee19_spring_day02"></property>
<property name="user" value="root"></property>
<property name="password" value="1234"></property>
</bean>
  <!-- 创建模板 ,需要注入数据源-->
<bean id="jdbcTemplateId" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSourceId"></property>
</bean> <!-- 配置dao注入模板 -->
<bean id="userDaoId" class="com.itheima.c_dbcp.UserDao">
<property name="jdbcTemplate" ref="jdbcTemplateId"></property>
</bean>

3.5   使用JdbcDaoSupport

3.5.1   dao层

说明UserDao继承的JdbcDaoSupport中已经实现了public void setJdbcTemplate(JdbcTemplate jdbcTemplate) 方法。

spring配置文件

<!-- 配置dao

* dao 继承 JdbcDaoSupport,之后只需要注入数据源,底层将自动创建模板

-->

<bean id="userDaoId" class="com.itheima.e_jdbcdaosupport.UserDao">

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

</bean>

3.6   配置properties

3.6.1   properties文件

jdbc.driverClass=com.mysql.jdbc.Driver

jdbc.jdbcUrl=jdbc:mysql://localhost:3306/ee19_spring_day02

jdbc.user=root

jdbc.password=1234

3.6.2   spring配置

  <!-- 加载配置文件
"classpath:"前缀表示 src下
在配置文件之后通过 ${key} 获得内容
-->
<context:property-placeholder location="classpath:com/itheima/f_properties/jdbcInfo.properties"/> <!-- 创建数据源 c3p0--> <bean id="dataSourceId" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${jdbc.driverClass}"></property> <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property> <property name="user" value="${jdbc.user}"></property> <property name="password" value="${jdbc.password}"></property> </bean>

Spring2的更多相关文章

  1. spring注解说明之Spring2.5 注解介绍(3.0通用)

    spring注解说明之Spring2.5 注解介绍(3.0通用) 注册注解处理器 方式一:bean <bean class="org.springframework.beans.fac ...

  2. Spring2.5与JDK8的集成问题

    Spring2.5不支持JDK8及其以上的版本,因为有一段校验JDK版本的代码,当JDK版本大于1.7之后,会识别成JDK1.4之前的.会报版本太低的错误. /* * Copyright 2002-2 ...

  3. Spring环境的搭建与测试 (spring2.5.6)

    这里是采用的视频里面的spring版本 下载spring2.5.6, 然后进行解压缩,在解压目录中找到下面jar文件,拷贝到类路径下 dist\spring.jar lib\jakarta-commo ...

  4. spring2.5

    1:IOC:控制反转,不再把依赖对象交给应用本身创建和维护,而是交给外部容器创建和维护.这样控制权由应用转移到外部容器.2:DI:依赖注入,在运行期,由外部容器动态的将依赖对象注入到组件中,可以通过构 ...

  5. spring2.5IOC控制反转详解

    spring2.5IOC控制反转详解 19. 五 / J2EE / 一条评论   基本的代码结构 1 IOC包下 基本的spring创建对象 将类添加到配置文件中,由容器创建. Source code ...

  6. 傅老师课堂:Java高级应用之Struts2+Spring2+Hibernate3大集成

    开篇一笑:一对情侣,非常恩爱,但男友喜欢说脏话,一天女友提出要带男友回家吃个饭,见见家长,千叮万嘱让男友别说脏话,男友在家憋了一晚上没说一句脏话,天气寒冷,到走的时候女友家长要出来送他们,男友客气的说 ...

  7. Spring2.0集成Quartz1.5.2调度框架

    Quartz是个开放源码项目,提供了丰富的作业调度集.希望您在阅读完本文并看过代码演示后,可以把Quartz的基本特性应用到任何Java™应用程序中.现代的Web应用程序框架在范围和复杂性方面都有所发 ...

  8. web学习:Spring2.5+Hibernate3.3+Struts1.3整合小例子

    写android有段时间了,感觉思维越写越狭窄,考虑问题越来越局限了,看不到一个项目整体的设计和构架,觉得很有必要多多写一些大型的框架性的东西来提高自己的视野. 从接触java到现在一年多了,在我的印 ...

  9. struts1.3整合spring2.5(将spring委托给struts方式)

    前提是配置完struts1.3 导包 spring-2.5.6.jar //spring核心包 spring-webmvc-struts-2.5.5.jar //struts整合spring使用 lo ...

  10. spring2.5与hibernate3升级后的bug

    手头有一个项目,使用的是struts2 hibernate3 spring2.5 是之前的老项目了,spring与hibernate的版本都比较低 自己看了最新的spring4与hibernate4, ...

随机推荐

  1. Java HashMap的put操作(Java1.6)

    https://www.cnblogs.com/skywang12345/p/3310835.html // 存储数据的Entry数组,长度是2的幂. // HashMap是采用拉链法实现的,每一个E ...

  2. Vue簡介

    vue使用由下向上的增量開發模型: vue是javascript的漸進框架: vue的目標是盡量使用簡單的API實現響應的數據綁定和組合的視圖組件.

  3. CSS 背景图片 添加 重复和定位。

    <!doctype html><html lang="en"> <head> <meta charset="UTF-8" ...

  4. LODOP中page-break-before:always给div分页

    Lodop中超过超文本打印项高度会自动分页:Lodop打印控件 超文本自动分页Lodop中还有NewPage和NewPageA,用于手动分页:Lodop强制分页LODOP.NewPage()和LODO ...

  5. Deploy .NET Core with Docker

    Creating a .NET Core project If you already have an existing .NET Core project you are more than wel ...

  6. HTC Vive 基础入门 基于Unity3D引擎

    任务2: 01-概述 07:08 任务3: 02-HTC Vive设备的安装 08:33 任务4: 03-下载Steam与SteamVR 03:05 任务5: 04-使用Steam VR 调试设备 1 ...

  7. [IOI2018]高速公路收费——二分查找+bfs

    题目链接: IOI2018highway 题目大意:给出一张$n$个点$m$条边的无向图,并给出一对未知的起点和终点,每条边都有两种边权$A$和$B$(每条边的$A$和$B$都分别相同),每次你可以设 ...

  8. ExaWizards 2019

    AB:div 3 AB??? C:div 1 C???场内自闭的直接去看D.事实上是个傻逼题,注意到物品相对顺序不变,二分边界即可. #include<iostream> #include ...

  9. Destroying the bus stations HDU - 2485(最小割点)

    题意: 就是求最小割点 解析: 正向一遍spfa 反向一遍spfa  然后遍历每一条边,对于当前边 如果dis1[u] + dis2[v] + 1 <= k 那么就把这条边加入到网络流图中, 每 ...

  10. eclipse中git推送上传错误 没有足够的数据写入

    Can't connect to any repository: https://github.com/jiashubing/test.git (https://github.com/jiashubi ...