mybatis-java-依赖注入
第一种 setXXX形式的注入
我们的所有dao都会继承自定义的BaseDao,因此在BaseDao中完成对所有dao的注入
在DaoUtil中增加方法injectDao()来注入具体的dao
package com.yangwei.shop.util;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Properties;
import com.yangwei.shop.dao.IDaoFactory;
/**dao工具类,主要使用反射机制*/
public class DaoUtil {
/**
* 思路:获取自己的所有方法,在判断是否有setXXX方法,如果有就对这个方法进行对象注入
*/
public static void injectDao(Object obj){
try {
//1,获取自己定义的所有方法
Method[] methods=obj.getClass().getDeclaredMethods();
for(Method method:methods){
//获取方法名
String mn=method.getName();
//2,查找set方法
if(mn.startsWith("set")){
//比如 setUserDao
mn=mn.substring(3);
mn=mn.substring(0, 1).toLowerCase()+mn.substring(1);
//3,从我们定义的工厂中获取dao对象
Object o=DaoUtil.createDaoFactory().getDao(mn);
//4,利用反射调用方法注入
//method是setXXX方法,调用者是this,参数是工厂取的具体dao对象
method.invoke(obj, o);
}
}
} catch (SecurityException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
public static IDaoFactory createDaoFactory(){
Properties prop = PropertiesUtil.getDaoProp();
try {
Class clz=Class.forName((String)prop.get("factory"));
String mm="getInstance";
Method method=clz.getMethod(mm);
//调用静态方法 使用类来调用
return (IDaoFactory)method.invoke(clz);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
在BaseDao类中增加构造来调用injectDao方法,目的是继承BaseDao的具体Dao内部可能有其它dao需要使用,完成注入
public BaseDao(){
DaoUtil.injectDao(this);
}
写一个基础测试类,完成对测试类中所有setXXX的注入,其实这里针对的是Dao的注入
package com.yangwei.shop.test;
import com.yangwei.shop.util.DaoUtil;
public class BaseTest {
public BaseTest(){
DaoUtil.injectDao(this);
}
}
每一个测试类继承BaseDao即可,写上get set方法即可,对用到的dao进行注入
package com.yangwei.shop.test;
import org.junit.Test;
import com.yangwei.shop.dao.UserDao;
public class TestInject extends BaseTest{
/**
* 测试set形式的依赖注入
*/
private UserDao userDao=null;
@Test
public void testSetDao(){
System.out.println(userDao);
}
public UserDao getUserDao() {
return userDao;
}
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
}
第二种 annotation形式的注入
自定义注解类
package com.yangwei.shop.entity;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/**
* 用这个annotation标注需要进行依赖注入的方法
* @ShopDi("userDao"),说明需要注入userDao对象
* 如果是@ShopDi就规定使用setXXX注入
*
*/
//必须让它在运行时能够执行
@Retention(RetentionPolicy.RUNTIME)
public @interface ShopDi {
/**
* value是Annotation的默认属性,在定义的时候可以不用vaule=""定义,而是直接通过
* @ShopDi("XXX")
* 特别注意,当需要定义两个以上的属性时,默认属性就不起作用了,此时需要如下形式定义
* @ShopDi(value="XXX",abc="YYY")
*/
String value() default "";
}
在DaoUtil中增加方法injectDao1()来注入具体的dao
/**
* 使用注解的形式,完成对Dao对象的注入
* @param obj
*/
public static void injectDao1(Object obj){
try {
//针对属性的注解
Field[] fields=obj.getClass().getDeclaredFields();
for(Field field:fields){
//有ShopDi的注解的属性
if(field.isAnnotationPresent(ShopDi.class)){
ShopDi shopDi=field.getAnnotation(ShopDi.class);
String value=shopDi.value();
if(value==null || "".equals(value.trim())){
//为空时,使用属性名称
value=field.getName();
}
Object o=DaoUtil.createDaoFactory().getDao(value);
//当属性被private修饰时,一定要设置可访问为true
field.setAccessible(true);
field.set(obj, o);
}
}
} catch (SecurityException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
基础测试类中,调用刚刚写的方法
package com.yangwei.shop.test;
import com.yangwei.shop.util.DaoUtil;
public class BaseTest {
public BaseTest(){
DaoUtil.injectDao(this);
}
}
具体的测试类继承BaseTest类,对需要注入dao的属性添加自定义注解
package com.yangwei.shop.test;
import org.junit.Test;
import com.yangwei.shop.dao.UserDao;
import com.yangwei.shop.entity.ShopDi;
public class TestAnnotation extends BaseTest{
@ShopDi("userDao")
private UserDao userDao;
@Test
public void abc(){
System.out.println(userDao);
}
}
mybatis-java-依赖注入的更多相关文章
- java依赖注入(injection)
和SpringSource分别通过其开源项目Guice及Spring Framework提供了依赖注入的功能.然而直到现在开发者也没有一种标准的.独立于供应商的方式从而无需修改其源文件就能在这些框架之 ...
- Java 依赖注入标准(JSR-330)简介
作者:88250 ,Vanessa 时间:2009 年 11 月 19 日 Java 依赖注入标准(JSR-330,Dependency Injection for Java)1.0 规范已 ...
- java依赖注入
接口的作用 1.在spide中创建一个私有接口 private Downloadable downlaodable 覆盖set get 方法 创建一个方法 Public Page down load ...
- java 依赖注入
https://blog.csdn.net/coderder/article/details/51897721 前言 在软件工程领域,依赖注入(Dependency Injection)是用于实现控制 ...
- Java依赖注入方式
pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...
- 开涛spring3(12.2) - 零配置 之 12.2 注解实现Bean依赖注入
12.2 注解实现Bean依赖注入 12.2.1 概述 注解实现Bean配置主要用来进行如依赖注入.生命周期回调方法定义等,不能消除XML文件中的Bean元数据定义,且基于XML配置中的依赖注入的 ...
- 注解实现Bean依赖注入
12.2.1 概述 注解实现Bean配置主要用来进行如依赖注入.生命周期回调方法定义等,不能消除XML文件中的Bean元数据定义,且基于XML配置中的依赖注入的数据将覆盖基于注解配置中的依赖注入的数 ...
- Android 和 Dagger 2 中的依赖注入
原文:Dependency Injection in Android with Dagger 2 作者:Joe Howard 译者:kmyhy 在现代开发团队中到处充斥着"你一定要用依赖注入 ...
- Objection, 一个轻量级的Objective-C依赖注入框架
简介 项目主页:https://github.com/atomicobject/objection 实例下载: https://github.com/ios122/ios122 Objection 是 ...
- Java之控制反转和依赖注入
1.简介 依赖注入和控制反转,目的是为了使类与类之间解耦合,提高系统的可扩展性和可维护性,下面通过一个例子来引入这一概念. 2.案例 1)一般情况下的类耦合 Main.java public clas ...
随机推荐
- Deadclock on calling async methond
Issue: HttpClient.GetAsync(…) never returns when using await/async Related Posts: http://stackoverfl ...
- HIVE—索引、分区和分桶的区别
一.索引 简介 Hive支持索引,但是Hive的索引与关系型数据库中的索引并不相同,比如,Hive不支持主键或者外键. Hive索引可以建立在表中的某些列上,以提升一些操作的效率,例如减少MapRed ...
- js 获取当前日期所在周的周一
function week(date,n) { var checkDate = StringToDate(date); checkDate.setDate(checkDate.getDate() + ...
- scrapy使用
我们都知道大名鼎鼎的爬虫框架scrapy,它是基于twisted框架基础上进行的封装,它是基于异步调用,所以爬取的速度会很快,下面简单介绍一下scrapy的组成. 首先我们先安装scrapy,如果是基 ...
- poj3876 darts
Darts Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 58 Accepted: 32 Special Judge ...
- JavaScript笔记之第四天
HTML DOM (文档对象模型) 当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). 查找 HTML 元素 通常,通过 JavaScript,您需要操作 ...
- 第一行代码_activity生命周期
这类文章基本上已经是烂大街了,不过我今天仍然要给自己做一遍梳理,因为通过昨天的项目我发现自己还是不太懂activity的各个生命周期;各位看官勿喷; 七个生命周期及其作用 oncreat 完成初始化操 ...
- 低版本浏览器支持HTML5标签的方法
最近刷了一道面试题,是关于低版本浏览器支持HTM5标签的写法,在网上找了一些,都行之有效,但是缺少整体总结,所以在这里总结一下,方便其他人过来阅读. IE低版本需要支持HTML5标签: 方法1.传统引 ...
- 正则语言引擎:一个简单LEX和YACC结合运用的实例
本文先描述了LEX与YACC的书写方法.然后利用LEX与YACC编写了一个简单正则语言的引擎(暂时不支持闭包与或运算),生成的中间语言为C语言. 正则引擎应直接生成NFA或DFA模拟器的输入文件,但在 ...
- jsp---jstl配置
关于eclipse中jstl标准标签库的配置问题 我的eclipse的版本是:Version: Neon.3 Release (4.6.3) 用的1.8.0_121的jre,Tomcat用的9.0, ...