SpringBoot 请求参数忽略大小写

import java.io.IOException;
import java.util.Collections;
import java.util.Enumeration;
import java.util.Map;

import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import javax.servlet.http.HttpServletResponse;

import org.springframework.core.annotation.Order;
import org.springframework.util.LinkedCaseInsensitiveMap;
import org.springframework.web.filter.OncePerRequestFilter;

@Order(1)
//重点
@WebFilter(filterName = "caseInsensitiveFilter", urlPatterns = "/*")
public class CaseInsensitiveRequestParameterNameFilter extends OncePerRequestFilter {

	public CaseInsensitiveRequestParameterNameFilter() {
		System.out.println("CaseInsensitiveRequestParameterNameFilter.CaseInsensitiveRequestParameterNameFilter()");
	}
	
    @Override
    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
            throws ServletException, IOException {
        filterChain.doFilter(new CaseInsensitiveParameterNameHttpServletRequest(request), response);
    }

    public static class CaseInsensitiveParameterNameHttpServletRequest extends HttpServletRequestWrapper {
        private final LinkedCaseInsensitiveMap<String[]> map = new LinkedCaseInsensitiveMap<>();

        public CaseInsensitiveParameterNameHttpServletRequest(HttpServletRequest request) {
            super(request);
            map.putAll(request.getParameterMap());
        }

        @Override
        public String getParameter(String name) {

            String[] array = this.map.get(name);
            if (array != null && array.length > 0)
                return array[0];
            return null;
        }

        @Override
        public Map<String, String[]> getParameterMap() {
            return Collections.unmodifiableMap(this.map);
        }

        @Override
        public Enumeration<String> getParameterNames() {
            return Collections.enumeration(this.map.keySet());
        }

        @Override
        public String[] getParameterValues(String name) {
            return this.map.get(name);
        }

    }

}

并在启动类上加入@ServletComponentScan注解

 

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot 是一个开发框架,用于构建基于Spring框架的Java应用程序。在使用Spring Boot时,我们可以使用多种方法对请求参数进行加密。 一种常见的方法是使用HTTPS来保护传输中的数据。HTTPS使用了SSL(Secure Sockets Layer)和TLS(Transport Layer Security)协议来加密HTTP请求和响应中的数据。我们可以在Spring Boot应用程序中配置HTTPS,使用自签名证书或者购买可信任的证书来建立安全的通信通道。 另一种方法是使用加密算法对请求参数进行加密。我们可以使用对称加密算法,如AES(Advanced Encryption Standard)或DES(Data Encryption Standard),将请求参数加密后再发送到服务器。服务器端接收到加密后的请求参数后,使用相同的密钥和算法进行解密,获取原始数据。 还有一种方法是使用数字签名来验证请求参数的完整性和真实性。我们可以使用非对称加密算法,如RSA(Rivest-Shamir-Adleman)算法,将请求参数进行签名。服务器端使用相应的公钥验证签名,确保请求参数未被篡改。 除此之外,还可以使用其他加密技术,如哈希函数或消息摘要算法对请求参数进行加密。哈希函数将请求参数转换成固定长度的摘要,服务器端接收请求参数后,将其进行相同的哈希运算,并与接收到的摘要进行比较,以验证参数的完整性。 在Spring Boot中,我们可以使用相应的加密算法和工具类来实现以上加密方法,保护请求参数的安全性。需要根据具体的需求和场景选择适合的加密方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值