-
Filter
-
概念∶
当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。 -
作用:
一般用于完成通用的操作。如∶【登录验证、统一编码处理、敏感字符过滤...】 -
快速入门:
步骤:
1.定义一个类,实现接口Filter
2.复写方法
3.配置拦截路径
拦截所有项目资源
@WebFilter("/*")
public class FilterDemo1 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void destroy() {
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("第一个Filter.......");
放行
filterChain.doFilter(servletRequest, servletResponse);
}
}
-
过滤器细节:
-
web.xml配置
<filter> <filter-name>demo1</filter-name> <filter-class>cn.itcast.web.filter.FilterDemo1</filter-class> </filter> <filter-mapping> <filter-name>demo1</filter-name> <--拦截路径--> <url-pattern>/*</url-pattern> </filter-mapping>
-
过滤器执行流程
1.执行过滤器
2.执行放行后的资源
3.回来执行过滤器放行代码下边的代码 -
过滤器生命周期方法
init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源
doFilter:每一次请求被拦截资源时,会执行。执行多次
destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源 -
过滤器配道详解
-
拦截路径配置:
1.具体资源路径:/index.jsp 只有访问index.jsp资源时,过滤器才会被执行
2.拦截目录:/user/* 访问/user下的所有资源时,过滤器都会被执行
3.后缀名拦截:*.jsp 访问所有后缀名为jsp资源时,过滤器都会被执行
4.拦截所有资源∶/* 访问所有资源时,过滤器都会被执行 -
拦截方式配置:
1. 注解配置:
@webFilter(value="/*",dispatcherTypes=DispatcherType.REQUEST)
@webFilter(value="/*",dispatcherTypes={DispatcherType.REQUEST,DispatcherType.FORWARD})
设置dispatcherTypes属性:
1.REQUEST:默认值。浏览器直接请求资源
2.FORWARD∶转发访问资源
3.INCLUDE :包含访问资源
4.ERROR:错误跳转资源
5.ASYNC:异步访问资源- web.xml配置
设置<dispatcher></dispatcher>标签即可
- web.xml配置
-
-
过滤器链(配置多个过滤器)
- 执行顺序:
1.过滤器1
2.过滤器2
3.资源执行
4.过滤器2
5.过滤器1
- 过滤器先后顺序问题:
1注解配置:按照类名的字符串比较规则比较,值小的先执行
如:AFilter和BFilter,AFilter就先执行了。
2.web.xml配置: <filter-mapping>谁定义在上边,谁先执行
- 执行顺序:
-
-
增强对象的功能:
设计模式:一些通用的解决固定问题的方式
- 代理模式:代理对象代理真实对象,达到增强真实对象功能的目的
- 实现方式∶
静态代理:有一个类文件描述代理模式
动态代理:在内存中形成代理类
实现步骤∶
1.代理对象和真实对象实现相同的接口
2.代理对象=Proxy.newProxyInstance;
3.使用代理对象调用方法。
4.增强方法。
增强方式:
1.增强参数列表
2.增强返回值类型
3.增强方法体执行逻辑
动态代理
public class ProxyTest {
public static void main(String[] args) {
//1,创建真实类对象
Proxy_lenovo lenovo = new Lenovo();
/**
* 动态代理增强lenove对象
* **参数:
* ***1,类加载器:真实对象.getClass().getClassLoader()
* ***2,接口数组:真实对象的接口 真实对象.getClass().getInterfaces()
* ***3,处理器:new InvocationHandler
*/
//2,lenovo的代理对象
Proxy_lenovo proxy_lenovo =(Proxy_lenovo) Proxy.newProxyInstance(lenovo.getClass().getClassLoader(), lenovo.getClass().getInterfaces(), new InvocationHandler() {
/*
代理逻辑编写的方法:所有对象(代理对象)的方法都会触发这个方法执行
参数:
proxy:代理参数对象
method:代理对象调用的方法,被封装为的对象
args:代理对象执行方法参数时,传递的实际参数
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
/* System.out.println("该方法执行了");
System.out.println(method.getName());
System.out.println(args[0]);*/
if(method.getName().equals("sale")){
//1,曾强参数列表
Double money=(Double) args[0]*0.85;
//3,增强方法体执行逻辑
System.out.println("车接车送");
String obj = (String) method.invoke(lenovo, money);//使用真实对象调用方法
//2,增强返回值
return obj+"+鼠标垫";
}else{
return method.invoke(lenovo, args);
}
}
});
//3,调用方法
String computer = proxy_lenovo.sale(8000.00);
System.out.println(computer);
//proxy_lenovo.show();
}
}
-
Listener :监听器:
概念: web的三大组件之一
事件监听机制
事件:一件事情
事件源:事件发生的地方
监听器:一个对象
注册监听︰将事件、事件源、监听器绑定在一起。当事件源上发生某个事件后,执行监听器代码
servletcontextListener:
监听servletcontext对象的创建和销毁
void contextDestroyed(servletContextEvent sce) : servletContext对象被销毁之前会调用该方法
void contextInitialized(ServletContextEvent sce) : servletContext对象创建后会调用该方法
网友评论