通用cms网站拓者室内设计网站
2026/4/18 17:05:17 网站建设 项目流程
通用cms网站,拓者室内设计网站,wordpress电商支付宝微信,WordPress对接微信公众号01 前言 Spring3.0引入了纯注解开发的模式#xff0c;框架的诞生是为了简化开发#xff0c;那注解开发就是简化再简化。Spring的特性在整合MyBatis方面体现的淋漓尽致哦 02 注解开发 以前跟老韩学习SE时他就说#xff1a; 注解本质是一个继承了Annotation 的特殊接口,其具…01前言Spring3.0引入了纯注解开发的模式框架的诞生是为了简化开发那注解开发就是简化再简化。Spring的特性在整合MyBatis方面体现的淋漓尽致哦02注解开发以前跟老韩学习SE时他就说注解本质是一个继承了Annotation 的特殊接口,其具体实现类是Java 运行时生成的动态代理类。而我们通过反射获取注解时,返回的是Java 运行时生成的动态代理对象$Proxy1。通过代理对象调用自定义注解(接口)的方法,会最终调用AnnotationInvocationHandler 的invoke 方法。该方法会从memberValues 这个Map 中索引出对应的值。而memberValues 的来源是Java 常量池。03注解定义Bean注解开发前配置Bean时是在xml里将class分别写在Bean标签里然后起id就像这样bean ida classyu7daily.Dao.Daoimpl.A /注解开发后配置Bean时首先将xml里的标签删掉然后在类上添加Component注解即可Component(a) public class A implements AA { public void save() { System.out.println(book dao save ... ); } }在xml文件中来写一个扫描包的注解标签对象就装进IOC容器里了context:component-scan base-packageyu7daily.Dao/component-scan:component意为组件scan意为扫描包路径越多扫描的范围越小速度越快·包路径越少扫描的范围越大速度越慢最后直接从容器获取对象public static void main(String[] args) { ApplicationContext ctx new ClassPathXmlApplicationContext(applicationContext.xml); A aa (A) ctx.getBean(a); bookService.save(); }这里要注意的是由于接口无法创建对象所以别把注解写在接口上注解真是神奇啊他和原先的xml里的Bean到底是什么关系呢04衍生注解对于Component还有衍生的三个注解Controller、Service、Repository结合与MVC的模式分别起到了补充的作用,方便我们后期在编写类的时候能很好的区分出这个类是属于表现层、业务层还是数据层的类05纯注解开发模式顾名思义纯注解的模式就是摒弃以前的配置操作全部由注解来完成Configuration类注解设置该类为Spring配置类ComponentScan类注解设置Spring配置类扫描路径1.写一个配置类通过注解Configuration来标注该类为配置类、ComponentScan来配置包扫描这样就替换掉了Configuration ComponentScan(yu7daily) public class Config {...}然后类就被放进了Bean里通过ApplicationContext acct new AnnotationConfigApplicationContext(Config.class);就可以得到Bean一顿操作下来我们通过一个Java类替换掉了Spring的核心配置文件完全告别了xml配置Bean作用域我们知道通过Bean造的对象默认都是单例的如何造出非单例的Bean?通过Scope注解即可属性值默认singleton单例可选值prototype非单例Component(a) Scope(prototype) public class A implements AA { public void save() { System.out.println(hello~); } }06注解实现注入Set注入的原理是通过set方法在容器内部将一个类设置到另一个类中这也是比较常用的方法。那么在纯注解开发的模式下如何实现注入呢Service public class A implements AA { Autowired private B b; }如上通过在属性上添加注解Autowired就实现了将B注入到A中1.自动装配在前面写配置文件的阶段autowire属性可以开启自动装配通常使用按类型装配autowirebyType对于自动装配的理解在set注入的基础上配置文件写的更加简洁因为在Service里写了set方法把Dao的对象搞到了Service里所以在配置Bean的时候我们通过自动装配在xml文件里实现了Service和Dao自动结合不再需要去Service里通过property标签来指定相应的name-ref自动装配基于反射设计创建对象并通过暴力反射为私有属性进行设值普通反射只能获取public修饰的内容暴力反射除了获取public修饰的内容还可以获取private修改的内容注解的模式就是体现形式的变式自动装配本质还是没有变2.按名称注入针对相同类型的Bean如果IOC中存在多个那按照类型注入一定会出错就像这样我通过注解注入的方式注入了两个AA的实现类到B中然后通过B来调用AA接口下的save()方法讲道理应该输出“hello~A”结果出现了NoUniqueBeanDefinitionException可见按照类型注入还是存在弊端啊如何解决我们可以通过按照名称注入的方式当根据类型在容器中找到多个bean,注入参数的属性名又和容器中bean的名称不一致这个时候该如何解决就需要使用到注解Qualifier 来指定注入哪个名称的bean对象在不修改其他条件下就像这样Repository(b) public class B implements BB { Autowired Qualifier(a) //注入指定的对象名称 private AA aa; public void save() { aa.save(); } }随着运行结果输出了A的成员方法说明注入成功值得注意的是Qualifier不能独立使用必须和Autowired一起使用3.简单数据注入通过注解value可以实现简单数据注入以String类型数据为例Repository(a) public class A implements AA { Value(hello java) private String str; public void save() { System.out.println(str); } } 运行结果hello其实上述操作看起来有点多此一举value主要还是为了读取配置文件而服务的4.读取properties配置文件首先在配置类上写上注解PropertySource用来指明读取目录下的哪个文件Configuration ComponentScan(yu7daily) PropertySource(test.properties) public class SpringConfig { }在相应的属性上配置Value注解即可完成配置文件属性的读取PS:配置文件内容——namelanyangyangRepository(a) public class A implements AA { Value(${name}) private String str; public void save() { System.out.println(str); } } 运行结果lanyangyang其实读取配置文件连接数据库也是这套操作07Spring整合MyBatis在配置好MyBatis的基础上不熟悉的可以去看一下以前写的MyBatis文章Spring的整合工作就变的非常简单主要工作就是管理MyBatis中的SqlSessionFactory和Mapper接口的扫描1.首先导入两个整合需要的的jar包artifactIdspring-jdbc/artifactId和13artifactIdmybatis-spring/artifactId2.配置数据源对象3.创建主配置类Configuration ComponentScan(yu7daily) PropertySource(classpath:jdbc.properties) 4Import({JdbcConfig.class,MybatisConfig.class}) public class SpringConfig {...}4.创建MyBatis配置类并获得SqlSessionFactory对象5.最后在主函数中得到对应的Bean即可进行对数据层的操作ApplicationContext ACC new AnnotationConfigApplicationContext(SpringConfig.class); AccountService acc ACC.getBean(AccountService.class);这工作量比原来是不是简单多了简直太哇塞了

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询