JavaWeb快速入门--Filter&Listener(1)

  • 过滤器的四种拦截方式:REQUEST、FORWARD、INCLUDE、ERROR

| 拦截方式 | 功能描述 |

| — | — |

| REQUEST | 直接访问目标资源时执行过滤器。包括:在地址栏中直接访问、表单提交、超链接、重定向,只要在地址栏中可以看到目标资源的路径,就是REQUEST |

| FORWARD | 转发访问执行过滤器。包括RequestDispatcher#forward()方法、<jsp:forward>标签都是转发访问 |

| INCLUDE | 包含访问执行过滤器。包括RequestDispatcher#include()方法、<jsp:include>标签都是包含访问 |

| ERROR | 当目标资源在web.xml中配置为中时,并且真的出现了异常,转发到目标资源时,会执行过滤器 |

注解配置:

  • @WebFilter(value="/index.jsp",dispatcherTypes = DispatcherType.REQUEST)

  • @WebFilter(value="/*",dispatcherTypes ={ DispatcherType.FORWARD,DispatcherType.REQUEST})

web.xml配置:<dispatcher>REQUEST</dispatcher>

案例:字符编码转换

@WebFilter(“/*”)

public class CharchaterFilter implements Filter {

protected String encoding;

public void destroy() {

// TODO Auto-generated method stub

}

public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {

//将父接口转换为子接口

HttpServletRequest request=(HttpServletRequest)req;

HttpServletResponse response=(HttpServletResponse)res;

//获取请求方法

String method=request.getMethod();

//解决post请求中文数据乱码问题

if(method.equalsIgnoreCase(“post”)) {

request.setCharacterEncoding(“utf-8”);

}

//处理响应乱码

response.setContentType(“text/html;charset=utf-8”);

chain.doFilter(request,response);

}

public void init(FilterConfig fConfig) throws ServletException {

// TODO Auto-generated method stub

}

}

案例:敏感词过滤

/**

  • 敏感词汇过滤器

*/

@WebFilter(“/*”)

public class SensitiveWordsFilter implements Filter {

public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {

//1.创建代理对象,增强getParameter方法

ServletRequest proxy_req = (ServletRequest) Proxy.newProxyInstance(req.getClass().getClassLoader(), req.getClass().getInterfaces(), new InvocationHandler() {

@Override

public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

//增强getParameter方法

//判断是否是getParameter方法

if(method.getName().equals(“getParameter”)){

//增强返回值

//获取返回值

String value = (String) method.invoke(req,args);

if(value != null){

for (String str : list) {

if(value.contains(str)){

value = value.replaceAll(str,“***”);

}

}

}

return value;

}

//判断方法是否是: getParameterMap

//判断方法是否是: getParameterValue

return method.invoke(req,args);

}

});

//2.放行

chain.doFilter(proxy_req, resp);

}

private List list = new ArrayList();//敏感词汇集合

public void init(FilterConfig config) throws ServletException {

try{

//1.获取文件真实路径

ServletContext servletContext = config.getServletContext();

String realPath = servletContext.getRealPath(“/WEB-INF/classes/敏感词汇.txt”);

//2.读取文件

BufferedReader br = new BufferedReader(new FileReader(realPath));

//3.将文件的每一行

String line = null;

while((line = br.readLine())!=null){

list.add(line);

}

br.close();

System.out.println(list);

}catch (Exception e){

e.printStackTrace();

}

}

public void destroy() {

}

}

/**

  • 验证方法

*/

@WebServlet(“/testServlet”)

public class TestServlet extends HttpServlet {

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

String name = request.getParameter(“name”);

String msg = request.getParameter(“msg”);

System.out.println(name+“:”+msg);

}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

this.doPost(request, response);

}

}

过滤器JavaWeb三大组件之一,当我们请求服务器的资源时,过滤器会在这组资源之前执行,它可以将我们的请求拦截下来,判断是否让我们访问这个资源,并完成一些特殊的功能。过滤器一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符过滤…

Listener:监听器


小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

结局:总结+分享

看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱

  • Java互联网工程师面试1000题

image.png

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

image.png

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

image.png

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

image.png

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

[外链图片转存中…(img-ZACE06pj-1710403074445)]

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

[外链图片转存中…(img-jzUbyWog-1710403074445)]

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

[外链图片转存中…(img-52cpBe8B-1710403074445)]

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值