基于注解的IOC
(99条消息) Spring基于注解的IoC配置_Demon_gu的博客-CSDN博客
也称为DI(Dependency Injection),它是IOC的具体实现技术
总的都是要创建对象,并且进行依赖的注入
1)创建对象的注解
@Componet:可以创建任意的对象
@Controller:专门可以创建控制器的对象(Servlet),这种对象可以接受用户的请求,可以返回处理结果给客户端
@Service:专门用来创建业务逻辑层的对象,负责向下访问数据访问层,处理完毕之后的结果返回给页面层
@Repository:专门用来访问数据访问层的对象,负责数据库里面的增删改查的各种操作
2)依赖注入的注解
@Value:用来简单类型的注入
引用类型的注入:
@Component
//pojo的类别
package org.example.s01.pojo;
import org.springframework.stereotype.Component;
@Component("stu")
public class Student {
private String name;
private int age;
public Student() {
System.out.println("你好啊");
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
//测试类
@Test
public void test01(){
ApplicationContext ax = new ClassPathXmlApplicationContext("s01/applicationContext.xml");
Student stu = (Student) ax.getBean("stu");
System.out.println(stu);
}
<context:component-scan base-package="org.example.s01"></context:component-scan>
@Value是数值的注入
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component("stu")
public class Student {
@Value("wsy")
private String name;
@Value("11")
private int age;
public Student() {
System.out.println("你好啊");
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
引用依赖的注入:必须是同源类型的注入a完全相同的类型b父子类c注入的类型是接口和实现类
@Autowired可以自己将类型注入
按名称来注入引用类型 还是要和Autpwired配合来使用的
@Autowired
@Qualifier("school")
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component("stu")
public class Student {
@Value("王小宇")
private String name;
@Value("19")
private int age;
@Autowired
@Qualifier("school")
private School school;
public Student() {
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
", school=" + school +
'}';
}
}
子类调用构建方法,不管是有参数还是没有参数,默认都会调用父类的无参构造方法
在父子类进行注入的时候,按类型进行注入的时候都是符合要求的但是进一步会根据名称再一次进行筛选,名字相同的则会被注入
三层架构的注解首先数据库层是@Repository 服务层是@Service 界面层控制层是@Controller
//数据库层
package org.example.dao;
import org.example.pojo.Users;
import org.springframework.stereotype.Repository;
@Repository
public class UserMapperImpl implements UserMapper{
@Override
public int insert(Users users) {
System.out.println("已经增加了用户");
return 1;
}
}
//服务层
package org.example.service.impl;
import org.example.dao.UserMapper;
import org.example.dao.UserMapperImpl;
import org.example.pojo.Users;
import org.example.service.UsersService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UsersServiceImpl implements UsersService {
@Autowired
UserMapper userMapper;
@Override
public int insert(Users users) {
return userMapper.insert(users);
}
}
//控制层
package org.example.controller;
import org.example.pojo.Users;
import org.example.service.UsersService;
import org.example.service.impl.UsersServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
@Controller
public class UserController {
@Autowired
UsersService usersService;
public int insert(Users users){
return usersService.insert(users);
}
}
公司做大型项目的时候,可以来按层拆也可以按着功能来拆
关于xml三层架构的项目的拆分与合并
批量导入就是可以用*号来代替这些名字
基于注解的方式就是扫描的时候,分层来扫描;一个文件夹里面放一层,然后分层去import
xml autowire的补充:
<bean id="school" class="org.example.pojo2.School">
<property name="address" value="湖北省武汉市"></property>
<property name="name" value="武汉市第一小学"></property>
</bean>
<bean id="student" class="org.example.pojo2.Student" autowire="byType">
<property name="name" value="ZZ"></property>
<property name="age" value="19"></property>
<!-- <property name="school" ref="school"></property>-->
</bean>