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 ...
随机推荐
- 自写JS分页工具【基于JQ】
好久没有来逛园子,也好久没有更新博客,就像沉睡已久的人忽然被叫醒,忽然就被园友的回复惊醒了.园友提出了关于我之前一篇文章的疑问--可那已经是半年以前的博客了,加上我一直觉得分享给大家的应该是我最新的思 ...
- 用DOS命令来运行Java代码
用DOS命令来运行Java代码.. ----------------- Demo.java public class Demo { public static void main(String[] a ...
- Form表单提交,Ajax请求,$http请求的区别
做过前端同学想必都避免不了要和后台server打交道.而以下这三种与后台交互的方式想必大家都不陌生. Form表单提交,Ajax请求,Angular的$http请求 以前一直搞不清楚什么时候应该用哪种 ...
- Java入门——学会使用API
API是什么? API(Application Programming Interface)就是别人写的代码使用说明书. 下面是中文版API的使用具体截图. 1.左上角有个显示(图中"隐藏& ...
- poj3368 uva11235 Frequent values
Description You are given a sequence of n integers a1 , a2 , ... , an in non-decreasing order. In ad ...
- [2017-07-18]ELK安装笔记
ELK ElasticSearch LogStash Kibana Server:CentOS 7 采用RPM导入官方源方式进行安装 rpm --import https://artifacts.el ...
- 延迟实例化 Lazy<T>
之前写的设计模式 单例模式中,推荐了使用Lazy<T>来达到线程安全和减少系统资源消耗的作用. 作用及优点: 创建某一个对象需要很大的消耗,而这个对象在运行过程中又不一定用到,为了避免每次 ...
- Begin the new life as a coder
今天刚刚开通博客园的博客频道,这里将成为自我成长点滴记录的土壤!从今天开始,从这篇博文开始,我将分享自己从一个fresher开始的成长经历.原与广大仁人志士共同在程序中共享快乐!我真是太高兴了 :D
- About the diffrence of wait timed_wait and block in java
import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * * @au ...
- this的用法 – JavaScript深入浅出(二)
写在前面 上一篇中,我们对于JavaScript中原始值.复杂值以及内存空间进行了一个深入浅出的总结,这次我们来聊一聊JavaScript中this关键字的深入浅出的用法. 在 JavaScript ...