JavaEE框架---Spring第三部分

摘要: 

  • Spring的AOP的注解(思想--)
    • AOP的相关的注解
      • @Aspect :定义切面
      • 通知的注解
        • @Before :前置通知
        • @AfterReturning :后置通知
        • @Around :环绕通知
        • @AfterThrowing :异常抛出通知
        • @After :最终通知
      • 切入点
        • @Pointcut :切入点
  • Spring的JDBC模板
    • Spring有持久层解决方案
    • 手动使用JDBC模板
    • 将连接池和JDBC模板交给Spring管理
    • 配置开源连接池
      • DBCP
      • C3P0
    • 使用JDBC模板完成CRUD的操作
  • Spring的事务管理
    • 事务回顾
    • Spring的事务管理的API
      • PlatformTransactionManager :平台事务管理器(真正管理事务)
        • DataSourceTransactionManager
        • HibernateTransactionManager
      • TransactionDefinition :事务定义信息
      • TransactionStatus :事务状态
    • Spring事务管理
      • 编程式事务管理(了解)
      • 声明式事务管理---底层思想就是AOP
        • XML
          • 引入aop开发包
          • 配置事务管理器
          • 配置增强<tx:Advice>
          • 配置aop
        • 注解
          • 引入aop开发包
          • 配置事务管理器
          • 开启注解事务
          • 在业务层添加注解

         


                  1.2Spring的AOP的基于AspectJ注解开发

1.2.1Spring的基于ApsectJ的注解的AOP开发
1.2.1.1创建项目,引入jar包 

1.2.1.2引入配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
	http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/context
	http://www.springframework.org/schema/context/spring-context.xsd
	http://www.springframework.org/schema/aop
	http://www.springframework.org/schema/aop/spring-aop.xsd
	http://www.springframework.org/schema/tx 
	http://www.springframework.org/schema/tx/spring-tx.xsd">
	
</beans>

1.2.1.3编写目标类并配置 

 1.2.1.4编写切面类并配置

1.2.1.5使用注解的AOP对象目标类进行增强

  • 在配置文件中打开注解的AOP开发

  • 在切面类上使用注解

1.2.1.6编写测试类

1.2.2Spring的注解的AOP的通知类型

1.2.2.1@Before    :前置通知

1.2.2.2@AfterReturning    :后置通知

1.2.2.3@Around        :环绕通知

1.2.2.4@AfterThrowing        :异常抛出通知

1.2.2.5@After        :最终通知

1.2.3Spring的注解的AOP的切入点的配置

1.2.3.1Spring的AOP的注解切入点的配置

  • 上面最终简化配置
/**
 * 切面类:注解的切面类
 */
@Aspect
public class MyAspectAnno {

	//前置通知
	@Before(value="MyAspectAnno.pointcut2()")
	public void before(){
		System.out.println("前置增强===========");
	}
	
	//后置通知
	@AfterReturning(value="MyAspectAnno.pointcut4()",returning="result")
	public void afterReturning(Object result){
		System.out.println("后置增强==========="+result);
	}
	
	//环绕通知
	@Around(value="MyAspectAnno.pointcut3())")
	public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
		System.err.println("环绕前通知=======");
		Object obj = joinPoint.proceed();
		System.out.println("环绕后通知==========");
		return obj;
	}
	
	// 异常抛出通知:
	@AfterThrowing(value="MyAspectAnno.pointcut1()",throwing="e")
	public void afterThrowing(Throwable e){
		System.out.println("异常抛出增强========="+e.getMessage());
	}
	
	// 最终通知
	@After(value="MyAspectAnno.pointcut1()")
	public void after(){
		System.out.println("最终增强============");
	}
	
	// 切入点注解:
	@Pointcut(value="execution(* com.itheima.spring.demo1.OrderDao.find(..))")
	private void pointcut1(){}
	@Pointcut(value="execution(* com.itheima.spring.demo1.OrderDao.save(..))")
	private void pointcut2(){}
	@Pointcut(value="execution(* com.itheima.spring.demo1.OrderDao.update(..))")
	private void pointcut3(){}
	@Pointcut(value="execution(* com.itheima.spring.demo1.OrderDao.delete(..))")
	private void pointcut4(){}
}
  • 完整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:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
	http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/context
	http://www.springframework.org/schema/context/spring-context.xsd
	http://www.springframework.org/schema/aop
	http://www.springframework.org/schema/aop/spring-aop.xsd
	http://www.springframework.org/schema/tx 
	http://www.springframework.org/schema/tx/spring-tx.xsd">
	
	<!-- 在配置文件中打开AOP的注解的开发 ===========-->
	<aop:aspectj-autoproxy/>
	
	<!-- 配置目标类 -->
	<bean id="orderDao" class="com.itheima.spring.demo1.OrderDao"></bean>	
	<!-- 配置切面类 -->	
	<bean id="myAspect" class="com.itheima.spring.demo1.MyAspectAnno"></bean>
			
</beans>


                       1.3Spring的JDBC的模板的使用

1.3.1Spring的JDBC的模板

Spring是EE开发的一站式的框架,有EE开发的每层的解决方案。Spring对持久层也提供了解决方案:ORM模块和JDBC的模板

Spring提供了很多的模板用于简化开发:

1.3.1.1JDBC模板使用的入门

  • 创建项目,引入jar包
    • 引入基本开发包:
    • 数据库驱动
    • Spring的JDBC模板的jar包

1.3.1.2创建数据库和表

create database spring4_day03;
use spring4_day03;
create table account(
	id int primary key auto_increment,
	name varchar(20),
	money double
);

1.3.1.3使用JDBC的模板:保存数据

1.3.2将连接池和模板交给Spring管理

1.3.2.1引入Spring的配置文件

1.3.2.2使用Jdbc的模板

  • 引入spring_aop的jar包

1.3.3使用开源的数据库连接池:

1.3.3.1DBCP的使用

  • 引入jar包

  • 配置DBCP连接池

1.3.3.2C3P0的使用

  • 引入c3p0连接池jar包

  • 配置c3p0连接池

1.3.4抽取配置到属性文件

1.3.4.1定义一个属性文件

  • jdbc.properties

1.3.4.2在Spring的配置文件中引入属性文件

  • 第一种:

  • 第二种:

1.3.4.3引入属性文件的值

1.3.4.4测试

1.3.5使用JDBC的模板完成CRUD的操作

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class JdbcDemo2 {

	@Resource(name="jdbcTemplate")
	private JdbcTemplate jdbcTemplate;
	
	//保存操作
	@Test
	public void demo1() {
		jdbcTemplate.update("insert into account values(null,?,?)","大圣",2000d);
	}
	//修改操作
	@Test
	public void demo2() {
		jdbcTemplate.update("update account set name= ? , money= ? where id= ? ","嘻嘻",1001d,3);
	}
	//删除操作
	@Test
	public void demo3() {
		jdbcTemplate.update("delete from account where id = ?",4);
	}
	
	@Test
	// 查询操作:
	public void demo4(){
		String name = jdbcTemplate.queryForObject("select name from account where id = ?", String.class, 5);
		System.out.println(name);
	}
	
	@Test
	// 统计查询
	public void demo5(){
		Long count = jdbcTemplate.queryForObject("select count(*) from account", Long.class);
		System.out.println(count);
	}
	
	@Test
	// 封装到一个对象中
	public void demo6(){
		Account account = jdbcTemplate.queryForObject("select * from account where id = ?", new MyRowMapper(), 5);
		System.out.println(account);
	}
	
	@Test
	// 查询多条记录
	public void demo7(){
		List<Account> list = jdbcTemplate.query("select * from account", new MyRowMapper());
		for (Account account : list) {
			System.out.println(account);
		}
	}
	//数据封装
	class MyRowMapper implements RowMapper<Account>{
		public Account mapRow(ResultSet rs, int rowNum) throws SQLException {
			Account account = new Account();
			account.setId(rs.getInt("id"));
			account.setName(rs.getString("name"));
			account.setMoney(rs.getDouble("money"));
			return account;
		}
	}
}


                               1.4Spring的事务管理

1.4.1事务的回顾

1.4.1.1什么事务

  • 事务:逻辑上的一组操作,组成这组操作的各个单元,要么全都成功,要么全都失败。

1.4.1.2事务的特性

  • 原子性:事务不可分割
  • 一致性:事务执行前后数据完整性保持一致
  • 隔离性:一个事务的执行不应该受到其他事务的干扰
  • 持久性:一旦事务结束,数据就持久化到数据库

1.4.1.3如果不考虑隔离性引发安全性问题

  • 读问题
    • 脏读 :一个事务读到另一个事务未提交的数据
    • 不可重复读 :一个事务读到另一个事务已经提交的update的数据,导致一个事务中多次查询结果不一致
    • 虚读、幻读 :一个事务读到另一个事务已经提交的insert的数据,导致一个事务中多次查询结果不一致。
  • 写问题
    • 丢失更新

1.4.1.4解决读问题

  • 设置事务的隔离级别
    • Read uncommitted :未提交读,任何读问题解决不了。
    • Read committed :已提交读,解决脏读,但是不可重复读和虚读有可能发生。
    • Repeatable read :重复读,解决脏读和不可重复读,但是虚读有可能发生。
    • Serializable :解决所有读问题。

1.4.2Spring的事务管理的API

1.4.2.1PlatformTransactionManager:平台事务管理器

  • 平台事务管理器:接口,是Spring用于管理事务的真正的对象。
    • DataSourceTransactionManager :底层使用JDBC管理事务
    • HibernateTransactionManager :底层使用Hibernate管理事务

1.4.2.2TransactionDefinition    :事务定义信息

  • 事务定义:用于定义事务的相关的信息,隔离级别、超时信息、传播行为、是否只读

1.4.2.3TransactionStatus:事务的状态

  • 事务状态:用于记录在事务管理过程中,事务的状态的对象。

1.4.2.4事务管理的API的关系:

         Spring进行事务管理的时候,首先平台事务管理器根据事务定义信息进行事务的管理,在事务管理过程中,产生各种状态,将这些状态的信息记录到事务状态的对象中。

1.4.3Spring的事务的传播行为

1.4.3.1Spring的传播行为

  • Spring中提供了七种事务的传播行为:

保证多个操作在同一个事务中

  • PROPAGATION_REQUIRED :默认值,如果A中有事务,使用A中的事务,如果A没有,创建一个新的事务,将操作包含进来
  • PROPAGATION_SUPPORTS :支持事务,如果A中有事务,使用A中的事务。如果A没有事务,不使用事务。
  • PROPAGATION_MANDATORY :如果A中有事务,使用A中的事务。如果A没有事务,抛出异常。

保证多个操作不在同一个事务中

  • PROPAGATION_REQUIRES_NEW :如果A中有事务,将A的事务挂起(暂停),创建新事务,只包含自身操作。如果A中没有事务,创建一个新事务,包含自身操作。
  • PROPAGATION_NOT_SUPPORTED :如果A中有事务,将A的事务挂起。不使用事务管理。
  • PROPAGATION_NEVER :如果A中有事务,报异常。

嵌套式事务

  • PROPAGATION_NESTED :嵌套事务,如果A中有事务,按照A的事务执行,执行完成后,设置一个保存点,执行B中的操作,如果没有异常,执行通过,如果有异常,可以选择回滚到最初始位置,也可以回滚到保存点。

1.4.4Spring的事务管理

1.4.4.1搭建Spring的事务管理的环境

  • 创建Service的接口和实现类

  • 创建DAO的接口和实现类

 

  • 配置Service和DAO:交给Spring管理

  • 在DAO中编写扣钱和加钱方法:
    • 配置连接池和JDBC的模板

  • 在DAO注入Jdbc的模板:传入一个连接池,dao的继承JdbcDaoSupport的直接生成jdbc模板

  • 测试

1.4.5Spring的事务管理:一类:编程式事务(需要手动编写代码)--了解

1.4.5.1第一步:配置平台事务管理器

1.4.5.2第二步:Spring提供了事务管理的模板类

1.4.5.3第三步:在业务层注入事务管理的模板

1.4.5.4编写事务管理的代码

1.4.5.5测试:

1.4.6Spring的事务管理:二类:声明式事务管理(通过配置实现)---AOP

1.4.6.1XML方式的声明式事务管理

  • 第一步:引入aop的开发包
  • 第二步:恢复转账环境
  • 第三步:配置事务管理器

  • 第四步:配置增强

  • 第五步:AOP的配置

  • 测试

dao的实现:

 seivice的实现:

测试类:

 

1.4.6.2注解方式的声明式事务管理

  • 第一步:引入aop的开发包
  • 第二步:恢复转账环境
  • 第三步:配置事务管理器

  • 第四步:开启注解事务

  • 第五步:在业务层添加注解

  • 测试:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tephra旨在构建一个稳定、高效、易于集群、快速扩展的JavaEE开发框架。目前,Tephra已经具备了以下特性: 提供类级别的热更新,但仅建议在需要快速修正严重BUG、并且无法立即进行全更新时使用。 提供全冗余方式的缓存,自动在每个节点间同步缓存数据,而每个节点都仅从本地内存中获取缓存数据,从而提供高效的执行效率,并且当部分节点宕机时仍旧能正常提供服务。当然,也允许使用Redis提供统一的中心节点缓存。此特性可用于多节点负载时提供不停服更新。 提供数据库读写分离、及读负载均衡,并且允许配置多个不同的数据库,甚至允许在运行期间增加新的数据库配置,并自动映射ORM。允许执行标准的SQL或存储过,同时提供了一个简单、轻量的ORM工具,并集成Hibernate、MyBatis为复杂ORM需求提供支持。 提供MongoDB工具实现对NoSQL的支持,支持负载均衡。 提供轻量级、快速响应的控制器,允许设置最大并发峰值,以确保在突如其来的并发攻击后能继续正常提供服务;也允许设置单IP最大并发量,确保小量IP并发攻击时仍能正常提供服务。允许发布为HTTP(S)、WebSocket、Socket服务。 提供JavaScript脚本引擎支持,允许JavaScript与JavaBean自由交互,并且可以发布JavaScript为服务;以及使用Javacript作为复杂规则验证器。 提供Hadoop存取支持。 模块化开发,使用注解简化配置,增强代码可读性与维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值