SpringBoot整合升级Spring Security 报错 【The request was rejected because the URL was not normalized】...

前言

最近LZ给项目框架升级, 从Spring1.x升级到Spring2.x, 在这里就不多赘述两个版本之间的区别以及升级的原因。

关于升级过程中踩的坑,在其他博文中会做比较详细的记录,以便给读者参考,不要掉进同样的坑里。 这里我们讨论一个关于URL中包含双斜杠被拦截的问题。

发现问题

升级框架之后,测试一个功能时,发现报错Http 500, 第一时间怀疑是后台功能报错。打印后台错误日志,发现报错信息:The request was rejected because the URL was not normalized。

之后与升级前相同环境对比发现,相同的功能, 升级之后,URL中包含双斜杠。

分析问题

经过对比不同和错误信息,初步定位问题出在URL上。查询资料得知,Spring Security 在高版本中增加了StrictHttpFirewall类,对URL校验更加严格。于是查看源码:

private static boolean isNormalized(String path) {
    if (path == null) {
        return true;
    } else if (path.indexOf("//") > -1) {
        return false;
    } else {
        int i;
        for(int j = path.length(); j > 0; j = i) {
            i = path.lastIndexOf(47, j - 1);
            int gap = j - i;
            if (gap == 2 && path.charAt(i + 1) == '.') {
                return false;
            }

            if (gap == 3 && path.charAt(i + 1) == '.' && path.charAt(i + 2) == '.') {
                return false;
            }
        }

        return true;
    }
}
解决问题

方法一:修改项目中出现“//”双斜杠的URL路径,哈哈

方法二:自定义FireWall方式允许URL出现双斜杠“//”

参考:Spring 5.0.3 RequestRejectedException: The request was rejected because the URL was not normalized

https://stackoverflow.com/questions/48453980/spring-5-0-3-requestrejectedexception-the-request-was-rejected-because-the-url/49116274

  1. 创建允许在URL中使用斜线的自定义防火墙。
@Bean
public HttpFirewall allowUrlEncodedSlashHttpFirewall() {
    StrictHttpFirewall firewall = new StrictHttpFirewall();
    firewall.setAllowUrlEncodedSlash(true);    
    return firewall;
}

2.在WebSecurity中配置这个bean。

@Override
public void configure(WebSecurity web) throws Exception {
    //@formatter:off
    super.configure(web);
    web.httpFirewall(allowUrlEncodedSlashHttpFirewall());
....
}

至此,问题解决。

转载于:https://www.cnblogs.com/lanxuan826/p/10997641.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于Spring Boot项目上传大文件报错 "the request was rejected because its size exceeds the configured maximum 10485760",这是因为默认情况下,Spring Boot限制了请求的大小为10MB。您可以通过以下几种方式解决这个问题: 1. 在application.properties或application.yml文件中添加以下配置,将请求大小限制扩大到您需要的大小(例如,20MB): ``` spring.servlet.multipart.max-request-size=20MB spring.servlet.multipart.max-file-size=20MB ``` 2. 如果您只想为特定的上传接口增加文件大小限制,可以在对应的Controller方法上添加注解: ```java @PostMapping("/upload") @MaxUploadSizeExceededExceptionHandler public void uploadFile(@RequestParam("file") MultipartFile file) { // 处理上传文件 } ``` 然后,在配置类中创建一个异常处理器: ```java @ControllerAdvice public class MaxUploadSizeExceededExceptionHandler { @ExceptionHandler(MaxUploadSizeExceededException.class) public ResponseEntity handleMaxUploadSizeExceededException(MaxUploadSizeExceededException e) { return ResponseEntity .status(HttpStatus.PAYLOAD_TOO_LARGE) .body("File size exceeds the limit!"); } } ``` 这样,当上传的文件大小超过限制时,将返回一个自定义的错误响应。 3. 如果您想处理更大的文件,建议考虑使用分片上传或将文件直接上传到云存储服务(如Amazon S3、七牛云等),然后在数据库中存储文件的元数据。 希望以上解决方案能帮到您!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值