1.工程环境搭建

2.基于注解的IOC配置

IOC注解的分类

(1)用于创建对象的
  他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的
@Component:
  作用:用于把当前类对象存入spring容器中
  属性:
    value:用于指定bean的id。当我们不写时,它的默认值是当前类名,且首字母改小写。

业务层实现类:AccountServiceImpl.java
package lucky.service.impl;

import lucky.service.IAccountService;
import org.springframework.stereotype.Component; /**
* 账户的业务层实现类
* xml的ioc配置
* <bean id="accountService" class="service.impl.AccountServiceImpl"></bean>
* <bean id="accountDao" class="dao.impl.AccountDaoImpl"></bean>
*/
@Component
public class AccountServiceImpl implements IAccountService { public AccountServiceImpl(){
System.out.println("对象创建了");
} public void saveAccount(){
System.out.println("AccountServiceImpl中的saveAccount方法执行了");
} }

表现层:

package lucky.ui;

import lucky.service.IAccountService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; /**
* 模拟一个表现层,用于调用业务层
*/
public class Client { public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); //2.根据id获取Bean对象,注意id是在bean.xml文件配置的
IAccountService as = (IAccountService)ac.getBean("accountServiceImpl");
System.out.println(as);
// as.saveAccount(); }
}

bean.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"
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"> <!--告知spring在创建容器时要扫描的包,配置所需要的标签不是在beans的约束中,而是一个名称为
context名称空间和约束中-->
<context:component-scan base-package="lucky"></context:component-scan>
</beans>

@ Controller:一般用在表现层
@ Service:一般用在业务层
@ Repository:一般用在持久层

持久层实现类:

package lucky.dao.impl;

import lucky.dao.IAccountDao;
import org.springframework.stereotype.Repository; /**
* 账户的持久层实现类
*/
@Repository
public class AccountDaoImpl implements IAccountDao { public void saveAccount(){
System.out.println("保存了账户");
}
}

表现层:

package lucky.ui;

import lucky.dao.IAccountDao;
import lucky.service.IAccountService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; /**
* 模拟一个表现层,用于调用业务层
*/
public class Client { /**
* 获取spring的Ioc核心容器,并根据id获取对象
*
* ApplicationContext的三个常用实现类:
* ClassPathXmlApplicationContext:它可以加载类路径下的配置文件,要求配置文件必须在类路径下。不在的话,加载不了。(更常用)
* FileSystemXmlApplicationContext:它可以加载磁盘任意路径下的配置文件(必须有访问权限)
*
* AnnotationConfigApplicationContext:它是用于读取注解创建容器的,是明天的内容。
*
* 核心容器的两个接口引发出的问题:
* ApplicationContext: 单例对象适用 采用此接口
* 它在构建核心容器时,创建对象采取的策略是采用立即加载的方式。也就是说,只要一读取完配置文件马上就创建配置文件中配置的对象。
*
* BeanFactory: 多例对象使用
* 它在构建核心容器时,创建对象采取的策略是采用延迟加载的方式。也就是说,什么时候根据id获取对象了,什么时候才真正的创建对象。
* @param args
*/
public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); //2.根据id获取Bean对象,注意id是在bean.xml文件配置的
IAccountService as = (IAccountService)ac.getBean("accountServiceImpl");
IAccountDao ad = (IAccountDao)ac.getBean("accountDaoImpl");
System.out.println(as);
System.out.println(ad);
// as.saveAccount(); }
}

以上三个注解他们的作用和属性与Component是一模一样。
他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰

(2)用于注入数据的
  他们的作用就和在xml配置文件中的bean标签中写一个<property>标签的作用是一样的
@Autowired:
  作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
    如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。
    如果Ioc容器中有多个类型匹配时:会报错(解决方案:配合@Qualifier的注解使用,指定具体用哪个类型)
  出现位置:
    可以是变量上,也可以是方法上

package lucky.service.impl;

import lucky.dao.IAccountDao;
import lucky.service.IAccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; /**
* 账户的业务层实现类
* xml的ioc配置
* <bean id="accountService" class="service.impl.AccountServiceImpl"></bean>
* <bean id="accountDao" class="dao.impl.AccountDaoImpl"></bean>
*/
@Component
public class AccountServiceImpl implements IAccountService { @Autowired
private IAccountDao iAccountDao; public void saveAccount(){
iAccountDao.saveAccount();
} }

细节:
在使用注解注入时,set方法就不是必须的了。
@ Qualifier:
  作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入时不能单独使用。但是在给方法参数注入时可以
  属性:
    value:用于指定注入bean的id。

举例:

有两个IAccountDao实现类时

AccountDaoImpl.java

package lucky.dao.impl;

import lucky.dao.IAccountDao;
import org.springframework.stereotype.Repository; /**
* 账户的持久层实现类
*/
@Repository(value = "accountDao1")
public class AccountDaoImpl implements IAccountDao { public void saveAccount(){
System.out.println("保存了账户--AccountDaoImpl");
}
}

AccountDaoImpl2.java

package lucky.dao.impl;

import lucky.dao.IAccountDao;
import org.springframework.stereotype.Repository; /**
* 账户的持久层实现类
*/
@Repository(value = "accountDao2")
public class AccountDaoImpl2 implements IAccountDao { public void saveAccount(){
System.out.println("保存了账户--AccountDaoImpl2");
}
}

业务层实现类

package lucky.service.impl;

import lucky.dao.IAccountDao;
import lucky.service.IAccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component; /**
* 账户的业务层实现类
* xml的ioc配置
* <bean id="accountService" class="service.impl.AccountServiceImpl"></bean>
* <bean id="accountDao" class="dao.impl.AccountDaoImpl"></bean>
*/
@Component
public class AccountServiceImpl implements IAccountService { //@Qualifier("accountDao1")指定用AccountDaoImpl生成的对象注入
@Autowired
@Qualifier("accountDao1")
private IAccountDao iAccountDao; public void saveAccount(){
iAccountDao.saveAccount();
} }

表现层

package lucky.ui;

import lucky.dao.IAccountDao;
import lucky.service.IAccountService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; /**
* 模拟一个表现层,用于调用业务层
*/
public class Client { public static void main(String[] args) {
//1.获取核心容器对象
ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); //2.根据id获取Bean对象,注意id是在bean.xml文件配置的
IAccountService as = (IAccountService)ac.getBean("accountServiceImpl");
// IAccountDao ad = (IAccountDao)ac.getBean("accountDaoImpl");
// System.out.println(as);
// System.out.println(ad);
as.saveAccount(); }
}

效果图:

@ Resource
  作用:直接按照bean的id注入。它可以独立使用
  属性:
     name:用于指定bean的id。

package lucky.service.impl;

import lucky.dao.IAccountDao;
import lucky.service.IAccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component; import javax.annotation.Resource; /**
* 账户的业务层实现类
* xml的ioc配置
* <bean id="accountService" class="service.impl.AccountServiceImpl"></bean>
* <bean id="accountDao" class="dao.impl.AccountDaoImpl"></bean>
*/
@Component
public class AccountServiceImpl implements IAccountService { //指定用id为accountDao2所对应的AccountDaoImpl2生成的对象注入
@Resource(name = "accountDao2")
private IAccountDao iAccountDao; public void saveAccount(){
iAccountDao.saveAccount();
} }

以上三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现。
另外,集合类型的注入只能通过XML来实现。

@ Value
  作用:用于注入基本类型和String类型的数据
   属性:
    value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
    SpEL的写法:${表达式}
(3)用于改变作用范围的
  他们的作用就和在bean标签中使用scope属性实现的功能是一样的
  @Scope
    作用:用于指定bean的作用范围
  属性:
    value:指定范围的取值。常用取值:singleton prototype
*
(4)和生命周期相关 了解
  他们的作用就和在bean标签中使用init-method和destroy-methode的作用是一样的
  PreDestroy
    作用:用于指定销毁方法
  PostConstruct
    作用:用于指定初始化方法

10 Spring框架--基于注解的IOC配置的更多相关文章

  1. 10 Spring框架--基于注解和xml的配置的应用案例

    1.项目结构 2.基于xml配置的项目 <1>账户的业务层接口及其实现类 IAccountService.java package lucky.service; import lucky. ...

  2. spring的基于注解的IOC配置

    1.配置文件配置 <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http: ...

  3. Spring 框架的概述以及Spring中基于XML的IOC配置

    Spring 框架的概述以及Spring中基于XML的IOC配置 一.简介 Spring的两大核心:IOC(DI)与AOP,IOC是反转控制,DI依赖注入 特点:轻量级.依赖注入.面向切面编程.容器. ...

  4. spring-第十七篇之spring AOP基于注解的零配置方式

    1.基于注解的零配置方式 Aspect允许使用注解定义切面.切入点和增强处理,spring框架可以识别并根据这些注解来生成AOP代理.spring只是用了和AspectJ 5一样的注解,但并没有使用A ...

  5. spring的纯注解的IOC配置

    package config; import com.mchange.v2.c3p0.ComboPooledDataSource;import org.apache.commons.dbutils.Q ...

  6. Spring中基于注解的IOC(二):案例与总结

    2.Spring的IOC案例 创建maven项目 导入依赖 pom.xml xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ...

  7. Spring中基于注解的IOC(一):基础介绍

    1. Spring中的常用注解 注解配置和xml配置要实现的功能都是一样的,都要降低程序的耦合,只是配置的形式不一样 xml中配置示例: 注解分类: 1.用于创建对象的注解 它们的作用就和在xml中编 ...

  8. 基于注解的IOC配置

    1 明确 注解配置和XML配置要实现的功能都是一样的,都是要降低程序间的耦合.只是配置的形式不一样. 关于实际的开发中到底是使用XML还是注解,每家公司有着不同的习惯.具体问题具体分析. 2 环境搭建 ...

  9. Spring 基于注解的 IOC 配置

    创建 spring 的 的 xml 配置 文件 <context:component-scan base-package="com.itheim"/> 指定创建容器时要 ...

随机推荐

  1. 全局异常捕获处理-@ControllerAdvice+@HandleException

    涂涂影院管理系统这个demo中有个异常管理的标签,用于捕获 涂涂影院APP用户异常信息 ,有小伙伴好奇,排除APP,后台端的是如何处理全局异常的,故项目中的实际应用已记之. 关于目前的异常处理 在使用 ...

  2. 洛谷 P3388 【模板】割点(割顶)题解

    今天学了割点,就A了这道板子,比较难理解的地方就在于如果是根节点就要找两个点来满足low[y]>=dfn[x],如果不是就只需找一个点来满足.Tarjan(i,i)中第一个i是开始搜索的点而第 ...

  3. BZOJ 5082: 弗拉格 矩阵乘法

    如果单点而不是求 sigma 的话还是比较好办的. 遇到这种前缀和相减的矩阵乘法可以增设一个 0 使得后面的能先加到前面,然后再算. 这样的话可以使的最后算出的是前缀和相加的形式. code: #in ...

  4. graphql-inspector graphql schema比较&&文档校验&&查找破坏性变动工具

    graphql-inspector 是一个方便的graphql 周边工具,可以加速graphql 应该的开发,同时可以帮助我们排查问题 包含以下特性: 进行schema 的比较 文档校验(通过sche ...

  5. 计蒜客 39280.Travel-二分+最短路dijkstra-二分过程中保存结果,因为二分完最后的不一定是结果 (The 2019 ACM-ICPC China Shannxi Provincial Programming Contest M.) 2019ICPC西安邀请赛现场赛重现赛

    Travel There are nn planets in the MOT galaxy, and each planet has a unique number from 1 \sim n1∼n. ...

  6. Web前端开发工具和环境清单

    初级 浏览器 Google Chrome 75.0.3770.100www.google.cn/intl/zh-CN/chrome初级 移动端模拟器 Genymotion 6.0.6www.genym ...

  7. javascript预览本地图片

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

  8. JavaScript操作BOM

    window对象的属性: history: 方法: back() 加载 history 对象列表中的前一个URL forward() 加载 history 对象列表中的下一个URL go() 加载 h ...

  9. Sybase数据库连接配置

    简介 1984年,Mark B. Hiffman和Robert Epstern创建了Sybase公司,并在1987年推出了Sybase数据库产品.SYBASE主要有三种版本,一是UNIX操作系统下运行 ...

  10. [JLOI 2015]骗我呢

    传送门 Description 求给\(n*m\)的矩阵填数的方案数 满足: \[ 1\leq x_{i,j}\leq m \] \[ x_{i,j}<x_{i,j+1} \] \[ x_{i, ...