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,jQuery实现可关闭悬浮框广告特效,兼容(谷歌,火狐,Ie)
注意不能直接用close()命名关闭广告函数,避免冲突. javascript实现方法: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tr ...
- 我的前端故事----关于redux的一些思考
背景 我一个前端,今年第一份工作就是接手一个 APP 的开发...一个线下 BD 人员用的推广 APP,为了让我这个一天原生开发都没有学过的人能快速开发上线,于是乎就选择了 react-native ...
- 给你的网站免费配置上 HTTPS 证书
现在越来越多的网站或服务增加了 HTTPS 证书,苹果 AppStore.微信小程序等也已强制要求开发者需提供 HTTPS 的后端接口.在阿里云 / 腾讯云上有一年期的免费赛门铁克 SSL 证书可供尝 ...
- C++重写(override)、重载(overload)、重定义(redefine)以及虚函数调用
一.基本概念 对于C++中经常出现的函数名称相同但是参数列表或者返回值不同的函数,主要存在三种情况: 1.函数重写(override) 函数重载主要实现了父类与子类之间的多态性,子类中定义与父类中名称 ...
- Varnsih调用多台后端主机
author:JevonWei 版权声明:原创作品 Varnsih调用多个后端主机 环境 Varnish 192.168.198.139 图片服务端 192.168.198.120 程序服务端 192 ...
- Centos 7 PXE一键安装
author:JevonWei 版权声明:原创作品 192.168.198.134作为安装服务器,由httpd服务共享安装程序 192.168.198.134作为dhcp服务器,客户机获取IP 一.安 ...
- 如何编写更好的SQL查询:终极指南-第三部分
本次我们学习<如何编写更好的SQL查询>系列的最后一篇文章. 时间复杂度和大O符号 通过前两篇文章,我们已经对查询计划有了一定了解.接下来,我们还可以借助计算复杂度理论,来进一步深入地挖掘 ...
- plsql developer 恢复默认布局界面
tools-preferences-appearance-(reset docking,reset toolbars)
- element-ui更换主题色
1.cd到你的项目文件目录下,npm i element-theme -g 2.npm i element-theme-default -D 3.et -i 执行后当前目录会有一个 element-v ...
- c# HttpWebRequest 模拟HTTP post 传递JSON参数
//HTTP post JSON 参数 private string HttpPost(string Url, Object ticket) { ...