java自定义注解高级,自定义注解

> 在本例中,把数据库连接的工具类DBUtil改造成为注解的方式,来举例演示怎么自定义注解以及如何解析这些自定义注解

# 步骤 1 : 非注解方式DBUtil

通常来讲,在一个基于JDBC开发的项目里,都会有一个DBUtil这么一个类,在这个类里统一提供连接数据库的IP地址,端口,数据库名称, 账号,密码,编码方式等信息。如例所示,在这个DBUtil类里,这些信息,就是以属性的方式定义在类里的。

大家可以运行试试,运行结果是获取一个连接数据库test的连接Connection实例。

```

package com.dodoke.util;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

public class DBUtil {

static String ip = "127.0.0.1";

static int port = 3306;

static String database = "test";

static String encoding = "UTF-8";

static String loginName = "root";

static String password = "123456";

static {

try {

Class.forName("com.mysql.jdbc.Driver");

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

public static Connection getConnection() throws SQLException {

String url = String.format("jdbc:mysql://%s:%d/%s?characterEncoding=%s", ip, port, database, encoding);

return DriverManager.getConnection(url, loginName, password);

}

public static void main(String[] args) throws SQLException {

System.out.println(getConnection());

}

}

```

# 自定义注解@JDBCConfig

接下来,就要把DBUtil这个类改造成为支持自定义注解的方式。 首先创建一个注解JDBCConfig

1. 创建注解类型的时候即不使用class也不使用interface,而是使用@interface

```

public @interface JDBCConfig

```

2. 元注解

`@Target({METHOD,TYPE})` 表示这个注解可以用用在类/接口上,还可以用在方法上

`@Retention(RetentionPolicy.RUNTIME) `表示这是一个运行时注解,即运行起来之后,才获取注解中的相关信息,而不像基本注解如@Override 那种不用运行,在编译时eclipse就可以进行相关工作的编译时注解。

`@Inherited` 表示这个注解可以被子类继承

`@Documented` 表示当执行javadoc的时候,本注解会生成相关文档

3. 注解元素,这些注解元素就用于存放注解信息,在解析的时候获取出来

```

String ip();

int port() default 3306;

String database();

String encoding();

String loginName();

String password();

```

```

package annotation;

import static java.lang.annotation.ElementType.METHOD;

import static java.lang.annotation.ElementType.TYPE;

import java.lang.annotation.Documented;

import java.lang.annotation.Inherited;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

@Target({ METHOD, TYPE })

@Retention(RetentionPolicy.RUNTIME)

@Inherited

@Documented

public @interface JDBCConfig {

String ip();

int port() default 3306;

String database();

String encoding();

String loginName();

String password();

}

```

# 注解方式DBUtil

有了自定义注解@JDBCConfig之后,我们就把非注解方式DBUtil改造成为注解方式DBUtil。

如例所示,数据库相关配置信息本来是以属性的方式存放的,现在改为了以注解的方式,提供这些信息了。

> 注: 目前只是以注解的方式提供这些信息,但是还没有解析,接下来进行解析

```

package com.dodoke.util;

import annotation.JDBCConfig;

@JDBCConfig(ip = "127.0.0.1", database = "test", encoding = "UTF-8", loginName = "root", password = "123456")

public class DBUtil2 {

static {

try {

Class.forName("com.mysql.jdbc.Driver");

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

}

```

# 解析注解

接下来就通过反射,获取这个DBUtil这个类上的注解对象

```

JDBCConfig config = DBUtil.class.getAnnotation(JDBCConfig.class);

```

拿到注解对象之后,通过其方法,获取各个注解元素的值:

```

String ip = config.ip();

int port = config.port();

String database = config.database();

String encoding = config.encoding();

String loginName = config.loginName();

String password = config.password();

```

后续就一样了,根据这些配置信息得到一个数据库连接Connection实例。

```

package com.dodoke.util;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

import annotation.JDBCConfig;

@JDBCConfig(ip = "127.0.0.1", database = "test", encoding = "UTF-8", loginName = "root", password = "123456")

public class DBUtil2 {

static {

try {

Class.forName("com.mysql.jdbc.Driver");

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

public static Connection getConnection() throws SQLException, NoSuchMethodException, SecurityException {

JDBCConfig config = DBUtil2.class.getAnnotation(JDBCConfig.class);

String ip = config.ip();

int port = config.port();

String database = config.database();

String encoding = config.encoding();

String loginName = config.loginName();

String password = config.password();

String url = String.format("jdbc:mysql://%s:%d/%s?characterEncoding=%s", ip, port, database, encoding);

return DriverManager.getConnection(url, loginName, password);

}

public static void main(String[] args) throws NoSuchMethodException, SecurityException, SQLException {

Connection c = getConnection();

System.out.println(c);

}

}

```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值