目录
2.Annotation的定义,没有解析就没有用。下一步解析!
1.引言:
1.1掌握Annotation的使用和解析。
1.2重新回顾反射的使用。
1.3初步了解MVVC框架的运行机制。
开胃菜:为什么使用框架?增加速度,提高开发效率。
页面提交的数据提交到哪里呢?Servlet(Controller)
控制层:控制什么呢?(承上启下的作用)
1.数据非空。
2.调用Servic。
3.数据封装。
4.转发与重定向。
1.Annotation
在JDK5之后,增加Annotation注解的基本语法
例如:@Override
Tar
Target:
对应的是当前的注解能够定义在哪个位置上,定义在只能放在方法之上之后就不可以放在类上,否则报错。
Retention:
在什么场景下能够起作用。
2.Annotation的定义,没有解析就没有用。下一步解析!
在
JDK5
之后,增加
Annotation
注解的基本语法,通 过注解可以省略XML
的配置信息,简化代码的编写形式。
在
Annotation
中,如果想要自定义,可以通过如下语法:
@Target(ElementType.xxxx)
@Retention(RetentionPolicy.xxxx)
public @interface 注解名 {
}
Target:
对应的是当前的注解能够定义在哪个位置上:
ElementType.Type -- 类
ElementType.Field --字段
ElementType.Method --方法
Retention:
在什么场景下能够起作用:
RetentionPolicy.CLASS - 定义类
RetentionPolicy.SOURCE - 编写代码
RetentionPolicy.RUNTIME --运行时(没有特殊情况,都是这个)
3. 解析Annotation
3.1 将所有包含了@Controller类进行遍历
扫描包的工具类:
package com.csi.utils;
import java.io.File;
import java.io.FileFilter;
import java.net.URL;
import java.net.URLDecoder;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
/**
* 找到某个包下的所有的以.class结尾的java文件
*/
public class ClassScanner {
/**
* 获得包下面的所有的class
* @param
* @return List包含所有class的实例
*/
public static List<Class<?>> getClasssFromPackage(String packageName) {
List<Class<?>> clazzs = new ArrayList<>();
// 是否循环搜索子包
boolean recursive = true;
// 包名对应的路径名称
String packageDirName = packageName.replace('.', '/');
Enumeration<URL> dirs;
try {
//从当前正在运行的线程中,加载类加载器,通过给定的包名,找到所有该包下的类
dirs = Thread.currentThread().getContextClassLoader().getResources(packageDirName);
while (dirs.hasMoreElements()) {
URL url = dirs.nextElement();
String protocol = url.getProtocol();
if ("file".equals(protocol)) {
String filePath = URLDecoder.decode(url.getFile(), "UTF-8");
findClassInPackageByFile(packageName, filePath, recursive, clazzs);
}
}
} catch (Exception e) {
e.printStackTrace();
}
return clazzs;
}
/**
* 在package对应的路径下找到所有的class
*/
public static void findClassInPackageByFile(String packageName, String filePath, final boolean recursive,
List<Class<?>> clazzs) {
File dir = new File(filePath);
if (!dir.exists() || !dir.isDirectory()) {
return;
}
// 在给定的目录下找到所有的文件,并且进行条件过滤
File[] dirFiles = dir.listFiles(new FileFilter() {
public boolean accept(File file) {
boolean acceptDir = recursive && file.isDirectory();// 接受dir目录
boolean acceptClass = file.getName().endsWith("class");// 接受class文件
return acceptDir || acceptClass;
}
});
for (File file : dirFiles) {
if (file.isDirectory()) {
findClassInPackageByFile(packageName + "." + file.getName(), file.getAbsolutePath(), recursive, clazzs);
} else {
String className = file.getName().substring(0, file.getName().length() - 6);
try {
clazzs.add(Thread.currentThread().getContextClassLoader().loadClass(packageName + "." + className));
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
为了程序一加载的时候就把所需要的map装载上,所以编写了监听器:
3.2解析用户的请求路劲
4.打包 jar包,pom.xml包
<packaging>jar</packaging> 或者不写,默认为jar包,并且删除没有用的包后,重构项目,之后就可以打包。
5.项目使用:
5.1.先添加依赖:
5.2.配置web.xml
5.3 使用:
-
需要在工程下建立 com.csi.controller 的包
-
在包中建立类,在该类上,添加 @Controller 的注解
-
建立类中的方法,根据需求,在适当的方法上添加@RequestMapping 注解
-
在 @RequestMapping 注解中添加 url 请求的路径