上海网站制作库榆,公司网站免费建立,百度旗下有哪些app,网址百度刷排名本文根据哔哩哔哩课程内容结合自己自学所得#xff0c;用于自己复习#xff0c;如有错误欢迎指正#xff1b; 我在想用一句话激励我自己努力学习#xff0c;却想不出来什么惊为天人、精妙绝伦的句子#xff0c;脑子里全是上课老师想说却没想起的四个字 “ 唯手熟尔 ”用于自己复习如有错误欢迎指正 我在想用一句话激励我自己努力学习却想不出来什么惊为天人、精妙绝伦的句子脑子里全是上课老师想说却没想起的四个字 “ 唯手熟尔 ”是啊不过唯手熟尔 目录
Spring注解式开发
自定义注解
自定义注解的使用
通过反射机制读取类上的注解
需求给你一个包名包中有很多对象然后将该包下实现了component注解的类存到一个map集合中其中注解ID为key实例化后的对象为value值
Spring声明Bean注解
Spring注解使用
选择实例化Bean
负责注入的注解
value注解
autowired注解
使用autowired注解的方式解决注入非简单类型的数据默认是根据类型装配的注意点有下面两点
如何解决上面的问题
Resource注解
Resource VS autowired
spring.xml也变成注解类 Spring注解式开发
首先回顾注解相关知识点 什么是注解 注解的定义格式 注解属性值的定义 如何使用注解
自定义注解 自定义注解的使用 通过反射机制读取类上的注解 需求给你一个包名包中有很多对象然后将该包下实现了component注解的类存到一个map集合中其中注解ID为key实例化后的对象为value值 Spring声明Bean注解
这里插入一个知识点其实注解就是元数据第一次接触元数据是在JDBC中所谓元注解就是修饰数据的数据这里的注解和xml配置信息也是元注解他们都是为了修饰数据
在Spring中声明容器管理的Bean的注解有四个 component service controller repository 其中只有component注解为原始注解但是为了提高可读性又给他起了下面三个别名源码如下 Target(value {ElementType.TYPE})//target是为了指定注解能够出现的地方Retention(value RetentionPolicy.RUNTIME)public interface Component {String value();}Target({ElementType.TYPE})Retention(RetentionPolicy.RUNTIME)DocumentedComponentpublic interface Controller {AliasFor(annotation Component.class)String value() default ;}Target({ElementType.TYPE})Retention(RetentionPolicy.RUNTIME)DocumentedComponentpublic interface Service {AliasFor(annotation Component.class)String value() default ;}Target({ElementType.TYPE})Retention(RetentionPolicy.RUNTIME)DocumentedComponentpublic interface Repository {AliasFor(annotation Component.class)String value() default ;}
Spring注解使用
使用注解的前期步骤 加入aop依赖引入Spring-context即可它里面包含了Spring-aop 在配置文件中添加context命名空间 ?xml version1.0 encodingUTF-8?beans xmlnshttp://www.springframework.org/schema/beansxmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexmlns:contexthttp://www.springframework.org/schema/contextxsi:schemaLocationhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd/beans 在配置文件中指定扫描的包 context:component-scan base-packagecom.powernode.spring6.bean///如果出现多个包的情况可以声明他们的共同父类或者通过逗号的方式同时声明多个包 在Bean类上使用注解 在Bean类上使用注解的几个小细节1在注解的使用中如果添加的是value属性其中value可以省略只需要写对应的值即可2如果我们在使用注解时不指定value属性的值时Spring会给我自动创建一个属性值采用默认方式即Bean类的名字首字母小写
选择实例化Bean
有时候我们有这样的需求将某个包下添加了component注解的Bean单独实例化其他的Bean都不实例化如何解决
Spring为我们提供了两种方式use-default-filter属性值为false或者true context:component-scan base-packagecom.powernode.spring6.bean3 use-default-filtersfalsecontext:include-filter typeannotation expressionorg.springframework.stereotype.Controller//context:component-scan
添加use-default-filter属性true时表示采用Spring默认规则实例化被四个注解标注的Bean
false表示不在使用默认的实例化规则全部都不实例化如果想要实例化某个注解就需要配置子标签contextinclude-filter并在其中声明需要实例化的注解
负责注入的注解
前面说了实例化Bean的注解component现在说替代set注入或者构造函数注入的注解
value注解
对于简单类型都可以使用value注解但是这种注解目前是硬编码耦合度太高我也不知道后面会咋弄直接在添加了component注解的类属性上添加value注解
Componentpublic class User {Value(value zhangsan)private String name;Value(20)private int age;}}
这种注入方式不依赖get\set方法而且value注解可以放在属性上、set方法上、构造方法上、或者构造方法的形参上
autowired注解
对于简单类型我们使用value注解那么对于复杂类型我们就使用autowired注解这种方式是自动装配在之前我们接触过基于xml文件的自动装配他是通过给Bean标签中添加autowire属性开启自动装配功能然后他的属性值就会开始自动装配底层调用的是set方法是通过方法名来自动装配的演示案例 bean iduserService classcom.powernode.spring6.service.UserService autowirebyName/bean idaaa classcom.powernode.spring6.dao.UserDao/public class UserService {// 这里没修改private UserDao aaa;/*public void setAaa(UserDao aaa) {this.aaa aaa;}*/// set方法名变化了,就无法自动装配了public void setDao(UserDao aaa){this.aaa aaa;}public void save(){aaa.insert();}} 使用autowire属性为byName这种自动装配时必须注意set方法名,还有一种是根据类型自动装配但是此时需要注意的是符合条件的实现类必须只有一个 无论是byName还是byType在装配的时候都是基于set方法的。而采用注解方式时就不依赖set方法了
使用autowired注解的方式解决注入非简单类型的数据默认是根据类型装配的注意点有下面两点 第一处该注解可以标注在哪里 构造方法上 方法上 形参上 属性上 注解上 span stylecolor:red第二处该注解有一个required属性默认值是true表示在注入的时候要求被注入的Bean必须是存在的如果不存在则报错。如果required属性设置为false表示注入的Bean存在或者不存在都没关系存在的话就注入不存在的话也不报错。/span
由于autowired注解采用的是默认的方式也就是byType类型所以实习类必须只有一个否则会报错
如何解决上面的问题
配合Qualifier注解同时使用在Qualifier注解中指明Bean标签的名称即可 AutowiredQualifier(userDaoForOracle) // 这个是bean的名字。public void setUserDao(UserDao userDao) {this.userDao userDao;}
总结 Autowired注解可以出现在属性上、构造方法上、构造方法的参数上、setter方法上。 当带参数的构造方法只有一个Autowired注解可以省略。多个的话就会报错 Autowired注解默认根据类型注入。如果要根据名称注入的话需要配合Qualifier注解一起使用。
Resource注解
这个注解使用的最广泛最受欢迎同样他的作用也是完成非简单类型的注入
Resource VS autowired
Resource注解也可以完成非简单类型注入。那它和Autowired注解有什么区别 Resource注解是JDK扩展包中的也就是说属于JDK的一部分。所以该注解是标准注解更加具有通用性。(JSR-250标准中制定的注解类型。JSR是Java规范提案。) Autowired注解是Spring框架自己的。 Resource注解默认根据名称装配byName未指定name时使用属性名作为name。通过name找不到的话会自动启动通过类型byType装配。 Autowired注解默认根据类型装配byType如果想根据名称装配需要配合Qualifier注解一起用。 Resource注解用在属性上、setter方法上。 Autowired注解用在属性上、setter方法上、构造方法上、构造方法参数上。
Resource注解属于JDK扩展包所以不在JDK当中需要额外引入以下依赖【如果是JDK8的话不需要额外引入依赖。高于JDK11或低于JDK8需要引入以下依赖。】
dependencygroupIdjakarta.annotation/groupIdartifactIdjakarta.annotation-api/artifactIdversion2.1.1/version/dependency
spring.xml也变成注解类
所谓的全注解开发就是不再使用spring配置文件了。写一个配置类来代替配置文件。
?xml version1.0 encodingUTF-8?beans xmlnshttp://www.springframework.org/schema/beansxmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexmlns:contexthttp://www.springframework.org/schema/contextxsi:schemaLocationhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsdcontext:component-scan base-packagecom.powernode.spring6.dao,com.powernode.spring6.service//beans
二者比较 ConfigurationComponentScan({com.powernode.spring6.dao, com.powernode.spring6.service})public class Spring6Configuration {}
但是相应的测试程序就需要改变了 Testpublic void testNoXml(){ApplicationContext applicationContext new AnnotationConfigApplicationContext(Spring6Configuration.class);UserService userService applicationContext.getBean(userService, UserService.class);userService.save();}
ClassPathXmlApplicationContext 类换成了 AnnotationConfigApplicationContext 他日若遂凌云志敢笑黄巢不丈夫加油