本文主要是介绍如何实现ip地址拉黑(过滤器类),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
- 一、过滤器
- 二、过滤器编程步骤
- 1、创建过滤器类
- 2、加载过滤器
- 三、实战代码
- MyFilter.java
- 四、效果
一、过滤器
过滤器(Filter)可以动态地拦截请求和响应。
◼ 应用场景:过滤敏感词汇、防止SQL注入、设置字符编码、进行URL级
别的权限访问控制、压缩响应信息等。
二、过滤器编程步骤
1、创建过滤器类
编写 Java 类实现 Filter 接口(主要是实现 doFilter() 方法);
过滤器类使用注解 @WebFilter 标注,并配置过滤 url。
过滤器类基本代码框架:
@WebFilter("/*") // 当前配置拦截所有请求
public class MyFilter implements Filter {
@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {if(某条件){//拦截处理}else{chain.doFilter(request, response); // 放行}}
}
2、加载过滤器
在 Spring Boot 启动类上添加 @ServletComponentScan 注解。
三、实战代码
本例 IP 黑名单以 127.0.0.1 和 localhost 为例:
以下请求均被过滤:
http://localhost:8080/
http://127.0.0.1:8080/
MyFilter.java
@ServletComponentScan
@WebFilter("/*")
public class MyFilter implements Filter {//黑名单 简单模拟一下private List<String> IPList=new ArrayList<>();@Overridepublic void init(FilterConfig filterConfig) throws ServletException { //过滤器初始化IPList.add("127.0.0.1"); // 本机地址IPList.add("0:0:0:0:0:0:0:1"); // IPv6 的本机地址}@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throwsIOException, ServletException {
//黑名单过滤String ip = servletRequest.getRemoteAddr(); // 获得客户端 ip 地址System.out.println(ip); //控制台上查看一下if( IPList.contains(ip) ){servletResponse.setContentType("text/html;charset=utf-8"); //设置响应的字符集(避免中文乱码)servletResponse.getWriter().println("你已被列入黑名单!");}else{filterChain.doFilter(servletRequest,servletResponse); //放行}}
}
四、效果
这篇关于如何实现ip地址拉黑(过滤器类)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!