最近在看B站颜群老师的课程,Javaweb>spring>springMVC>mybatis>spring高级,一路走来,跌跌撞撞,发现spring也不过尔尔,说白了,spring就是想尽办法将new做的更简单,更完美,更可配置。 Spring的一个核心功能是IOC,就是将Bean初始化加载到容器中,Bean是如何加载到容器的,可以使用Spring注解方式或者Spring XML配置方式。 Spring注解方式减少了配置文件内容,更加便于管理,并且使用注解可以大大提高了开发效率! 注解本身是没有功能的,和xml一样,注解和xml都是一种元数据,元数据即解释数据的数据,也就是所谓的配置。
//扫描指定包下的全部的标有@Component的类,并注册成bean.
<context:component-scan base-package="com.guo"></context:component-scan>
<context:annotation-config/>包扫描+组件标注注解 @Component:泛指各种组件 @Controller、@Service、@Repository都可以称为@Component。 @Controller:控制层 @Service:业务层 @Repository:数据访问层 @Bean: 导入第三方包里面的注解 @Import(要导入到容器中的组件);
@Import({Color.class, MyImportSelector.class, MyImportBeanDefinitionRegistrar.class})
public class MainConfig2 {
@Scope("prototype")
@Bean("person")
public Person person() {
System.out.println("我是Person");
return new Person("素小暖",25);
}
}@ImportSelector:返回需要导入的组件的全类名数组;
public class MyImportBeanDefinitionRegistrar implements ImportBeanDefinitionRegistrar {
/*
* AnnotationMetadata:当前类的注解信息
* BeanDefinitionRegistry:BeanDefinition注册类
* 把所有需要添加到容器中的bean,调用BeanDefinitionRegistry.registerBeanDefinition手动注入
*
* */
public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry) {
boolean definition = registry.containsBeanDefinition("com.atguigu.bean.Red");
boolean definition2 = registry.containsBeanDefinition("com.atguigu.bean.Blue");
if(definition && definition2){
//指定bean定义信息(bean的类型,bean的scope)
RootBeanDefinition rootBeanDefinition = new RootBeanDefinition(RainBow.class);
//注册一个bean,指定bean名
registry.registerBeanDefinition("rainBow",rootBeanDefinition);
}
}
}使用 spring 提供的 FactoryBean(工厂 Bean) 默认获取到的是工厂 Bean 调用 getObject 创建的对象 要获取工厂 Bean 本身,需要在 id 前面加一个 &
@Bean
public ColorFactoryBean colorFactoryBean(){
return new ColorFactoryBean();
}//创建一个spring定义的FactoryBean
public class ColorFactoryBean implements FactoryBean<Color> {
//返回一个Color对象,并将Color添加到容器中
public Color getObject() throws Exception {
System.out.println("ColorFactoryBean,getObject()");
return new Color();
}
public Class<?> getObjectType() {
return Color.class;
}
public boolean isSingleton() {
return false;
}
}
@Autowired:由bean提供
@Inject:由JSR-330提供
@Resource:由JSR-250提供 @Autowired、@Inject是默认按照类型匹配的,@Resource是按照名称匹配的,@Autowired如果需要按照名称匹配需要和@Qualifier一起使用,@Inject和@Name一起使用。 @Primary 让spring进行自动装配的时候,默认使用首选的bean,和@Qualifier一个效果。
Java配置类相关注解
@Configuration 声明当前类为配置类; @Bean 注解在方法上,声明当前方法的返回值为一个bean,替代xml中的方式; @ComponentScan 用于对Component进行扫描;
Spring AOP详细介绍 Spring支持AspectJ的注解式切面编程。 @Aspect 声明一个切面 @After 在方法执行之后执行(方法上) @Before 在方法执行之前执行(方法上) @Around 在方法执行之前与之后执行(方法上) @PointCut 声明切点 在java配置类中使用@EnableAspectJAutoProxy注解开启Spring对AspectJ代理的支持
@Bean的属性支持
@Scope设置类型包括: 设置Spring容器如何新建Bean实例(方法上,得有@Bean) ① Singleton (单例,一个Spring容器中只有一个bean实例,默认模式), ② Protetype (每次调用新建一个bean), ③ Request (web项目中,给每个http request新建一个bean), ④ Session (web项目中,给每个http session新建一个bean), ⑤ GlobalSession (给每一个 global http session新建一个Bean实例)
支持如下方式的注入:
@Value三种情况的用法。
@Profile 指定组件在哪个环境的情况下才能被注册到容器中,不指定,任何环境下都能注册这个组件。 @Conditional 通过实现Condition接口,并重写matches方法,从而决定该bean是否被实例化。
@EnableAsync 配置类中通过此注解开启对异步任务的支持; @Async 在实际执行的bean方法使用该注解来声明其是一个异步任务(方法上或类上所有的方法都将异步,需要@EnableAsync开启异步任务)
@EnableScheduling 在配置类上使用,开启计划任务的支持(类上) @Scheduled 来申明这是一个任务,包括cron,fixDelay,fixRate等类型(方法上,需先开启计划任务的支持)
1、@EnableWebMvc 在配置类中开启Web MVC的配置支持。 2、@Controller 3、@RequestMapping 用于映射web请求,包括访问路径和参数。 4、@ResponseBody 支持将返回值放到response内,而不是一个页面,通常用户返回json数据。 5、@RequestBody 允许request的参数在request体中,而不是在直接连接的地址后面。(放在参数前) 6、@PathVariable 用于接收路径参数,比如@RequestMapping(“/hello/{name}”)声明的路径,将注解放在参数前,即可获取该值,通常作为Restful的接口实现方法。 7、@RestController 该注解为一个组合注解,相当于@Controller和@ResponseBody的组合,注解在类上,意味着,该Controller的所有方法都默认加上了@ResponseBody。 8、@ControllerAdvice 全局异常处理 全局数据绑定 全局数据预处理 9、@ExceptionHandler 用于全局处理控制器里的异常。 10、@InitBinder 用来设置WebDataBinder,WebDataBinder用来自动绑定前台请求参数到Model中。 11、@ModelAttribute (1)@ModelAttribute注释方法 如果把@ModelAttribute放在方法的注解上时,代表的是:该Controller的所有方法在调用前,先执行此@ModelAttribute方法。可以把这个@ModelAttribute特性,应用在BaseController当中,所有的Controller继承BaseController,即可实现在调用Controller时,先执行@ModelAttribute方法。比如权限的验证(也可以使用Interceptor)等。 (2)@ModelAttribute注释一个方法的参数 当作为方法的参数使用,指示的参数应该从模型中检索。如果不存在,它应该首先实例化,然后添加到模型中,一旦出现在模型中,参数字段应该从具有匹配名称的所有请求参数中填充。