体系结构:
1、Spring core 是spring框架的核心,提供了IOC和依赖注入特性
2、Spring Context 提供了一种框架风格的方式来访问对象,继承了beans包的功能,同时增加了国际化、事件传播、资源装载、以及透明创建上下文
3、Spring AOP 通过配置管理,直接将面向方面编程集成到了框架之中。
4、Spring DAO 提供了JDBC的抽象层。可以消除冗长的JDBC编码和数据库厂商特有的错误代码
开发步骤:
1、引入spring jar包
2、添加applicationContext.xml
3、创建一个javabean里面属性有set get方法即可
4、配置applicationContext.xml
5、开发测试
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Hello bean1 = (Hello) ac.getBean("he");//第1种获取bean方式,需要强转
Hello bean2 = ac.getBean("he", Hello.class);//第2种获取bean方式
System.out.println(bean1.getHello());
控制反转:
控制反转(IOC--Inversion of control)所谓控制反转就是应用本身不负责依赖对象的创建及维护,依赖对象的创建及维护是由外部容器负责的。这样控制权就由应用转移到了外部容器,控制权的转移就是所谓反转
依赖注入:
注入方式:
1、set 注入
2、构造方法注入
3、参考注入(接口注入)
数组注入:
1 、public class Teacher {
private String[]info;//数组
private List list;//List集合
private Set set;//Set集合
private Map map;//Map键值对
//所以对象都有set get方法。。。。
2、
教授
副教授
高工
博士
硕士
学士
北京
上海
南京
3、
ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext.xml");
Teacher tea = ac.getBean("tea",Teacher.class);
String[] info = tea.getInfo();//取出数组
for(String ss:info){
System.out.println(ss);}
List list = tea.getList();//取出List集合
for(int i=0;i
五种类型通知:
1、前置通知[Before advice]:在连接点前面执行,前置通知不会影响连接点的执行,除非此处抛出异常。
3、正常返回通知[After returning advice]:在连接点正常执行完成后执行,如果连接点抛出异常,则不会执行。
3、异常返回通知[After throwing advice]:在连接点抛出异常后执行。
4、返回通知[After (finally) advice]:在连接点执行完成后执行,不管是正常执行完成,还是抛出异常,都会执行返回通知中的内容。
5、环绕通知[Around advice]:环绕通知围绕在连接点前后,比如一个方法调用的前后。这是最强大的通知类型,能在方法调用前后自定义一些操作。环绕通知还需要负责决定是继续处理join point(调用ProceedingJoinPoint的proceed方法)还是中断执行。
aop和oop区别:
1、oop是java在面向对象编程
aop是面向切面编程,AOP主要应用于日志记录,性能统计,安全控制,事务处理等方面,它是为程序员解耦而生.
aop全注解开发:
注解名 说明
@Controller 注解控制层组件,(如struts中的action)
@Service 注解业务层组件,service层组件
@Repository 注解数据访问层组件,DAO层组件
@Component 泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注
@Autowired 默认是按照类型装配注入(spring)
@Resource 默认是按照名称来装配注入(j2ee)
@Scope 注解用于指定scope作用域的(用在类上)
@Transactional 添加事务
注解配置AOP,为三步
1)使用注解@Aspect来定义一个切面,在切面中定义切入点(@Pointcut),通知类型(@Before、 @After 、@AfterReturning 、@AfterThrowing 、@Around )
2)开发需要被拦截的类
3)将切面配置到xml中,也可以使用自动扫描bean方式
案例:
@Aspect// 使用spring 全注解定义一个切面
@Component("aop")
// 泛指组件当组件不好归类的时候,我们可以使用这个注解进行标注
public class AspInterceptor {
@Before("execution(* com.hw.service..*.add*(com.hw.entity.Student))")
public void before() {// 前置通知
System.out.println("before....使用本程序先交9美金!!!");
}
@AfterReturning("execution(* com.hw.service.impl.*.add*(String))")
public void after() {// 正常返回通知
System.out.println("after....程序使用正常9美金很值!!!");
}
@AfterThrowing("execution(* com.hw.service.impl.*.*(..))")
public void afterthrowing() {// 异常返回通知
System.out.println("throwing....程序使用有异常9美金上当了!!!");
}
@After("execution(* com.hw.service.impl.*.add*(..))")
public void afterfinally() {// 返回最终通知
System.out.println("afterfinally....别想着程序了,9美金已交了!!!");
}
@Around("execution(* com.hw.service.impl.*.update*(..))")
public void around(ProceedingJoinPoint pj) throws Throwable {// 环绕通知
System.out.println("环绕通知,要工作了");
pj.proceed();
System.out.println("环绕通知,要发工资了");
/*
* 环绕通知:能在方法调用前后自定义一些操作。环绕通知还需要负
* 责决定是继续处理join point(调用ProceedingJoinPoint的
* proceed方法)还是中断执行
*/
}
spring中配置数据源的4中形式:
spring自带的数据源(DriverManagerDataSource),DBCP数据源,C3P0数据源,JNDI数据源。
实际开发中一般使用
1 DBCP数据源(http://www.cnblogs.com/adolfmc/archive/2013/01/22/2872298.html)
DBCP的配置依赖于2个jar包commons-dbcp.jar,commons-pool.jar
2 C3P0是一个开放源代码的JDBC数据源实现项目,C3P0依赖于jar包c3p0.jar