Spring Boot使用过滤器过滤非法URL

一、场景

使用Spring Boot框架,通过过滤器过滤不存在的URL,将这些非法URL转发或重定向到自定义错误页面。

二、实现

API:

  • WebApplicationContext:用于获取全局信息
  • ServletRequest:用于获取请求地址的URI

补充:
URL和URI的区别
示例:https://www.tomyres.com/soft/?page=2&show_page=15

其中,URL为 https://www.tomyres.com/soft/,URI为 /soft/,即URL包含URI,URI没有host部分,也不包含参数部分。

1.获取全局配置

@Resource
WebApplicationContext applicationContext;

2.获取所有方法的请求路径URI(如:@RequestMapping)

RequestMappingHandlerMapping mapping = applicationContext
  .getBean(RequestMappingHandlerMapping.class);
// 获取url与类和方法的对应信息
Map<RequestMappingInfo, HandlerMethod> map = mapping
        .getHandlerMethods();

List<String> urls = new ArrayList<>();
for (RequestMappingInfo info : map.keySet()) {
    // 获取每个方法的url的Set集合,一个方法可能对应多个url
    Set<String> patterns = info.getPatternsCondition().getPatterns();
    //将所有url添加到urls集合
    urls.addAll(patterns);
}

3.获取客户端请求URI,过滤非法URI,跳转到自定义错误页面

HttpServletRequest request = (HttpServletRequest) servletRequest;

if (urls.contains(request.getRequestURI()))
    filterChain.doFilter(servletRequest,servletResponse);
else
    servletRequest.getRequestDispatcher("/failed")
            .forward(servletRequest,servletResponse);

4.完整代码

package com.example.hw3.filter;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.mvc.method.RequestMappingInfo;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping;

import javax.annotation.Resource;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;


@WebFilter(filterName = "commonFilter",urlPatterns = "/*")
public class CommonFilter implements Filter {

    private Logger logger = LoggerFactory.getLogger(this.getClass());
    @Resource
    WebApplicationContext applicationContext;
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        logger.info("init方法执行了");

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        logger.info("doFilter方法执行了");
        RequestMappingHandlerMapping mapping = applicationContext
                .getBean(RequestMappingHandlerMapping.class);
        // 获取url与类和方法的对应信息
        Map<RequestMappingInfo, HandlerMethod> map = mapping
                .getHandlerMethods();

        List<String> urls = new ArrayList<>();
        for (RequestMappingInfo info : map.keySet()) {
            // 获取每个方法的url的Set集合,一个方法可能对应多个url
            Set<String> patterns = info.getPatternsCondition().getPatterns();
            //将所有url添加到urls集合
            urls.addAll(patterns);
        }

        HttpServletRequest request = (HttpServletRequest) servletRequest;

        if (urls.contains(request.getRequestURI()))
            filterChain.doFilter(servletRequest,servletResponse);
        else
            servletRequest.getRequestDispatcher("/failed")
                    .forward(servletRequest,servletResponse);
    }

    @Override
    public void destroy() {
        logger.info("destroy方法执行了");

    }
}

三、测试

正常访问

在这里插入图片描述
输入不存在的URL
在这里插入图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
是的,Spring Boot可以使用过滤器(Filter)来过滤非法字符。可以在过滤器中对请求进行预处理和后处理,比如字符编码转换、参数校验、安全控制等。以下是一个示例过滤器,它可以过滤请求中的非法字符: ```java @Component public class IllegalCharacterFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { // 初始化过滤器 } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) servletRequest; HttpServletResponse response = (HttpServletResponse) servletResponse; // 进行字符编码转换 request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("UTF-8"); // 获取请求参数 Map<String, String[]> parameterMap = request.getParameterMap(); for (Map.Entry<String, String[]> entry : parameterMap.entrySet()) { String name = entry.getKey(); String[] values = entry.getValue(); for (int i = 0; i < values.length; i++) { String value = values[i]; // 过滤非法字符 if (containsIllegalCharacter(value)) { response.sendError(HttpServletResponse.SC_BAD_REQUEST, "包含非法字符"); return; } } } // 执行下一个过滤器或目标资源 filterChain.doFilter(request, response); } @Override public void destroy() { // 销毁过滤器 } private boolean containsIllegalCharacter(String value) { // 判断是否包含非法字符,例如 <script>、alert() 等 return value.contains("<script>") || value.contains("alert("); } } ``` 在上述示例中,IllegalCharacterFilter 实现了 Filter 接口,并通过 @Component 注解将其注册为 Spring Bean。在 doFilter 方法中,通过 request.setCharacterEncoding 和 response.setCharacterEncoding 进行字符编码转换,然后获取请求参数并遍历每个参数值,判断是否包含非法字符。如果包含非法字符,则直接返回错误响应,否则执行下一个过滤器或目标资源。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值