springboot 拦截器统一处理post get 以及文件上传

1.思想

核心思想,在拦截器中将前端的参数封装到map中,然后将map放入HttpServletRequest中,如果是文件上传,那直接在拦截器将文件内容处理好,放入HttpServletRequest中,。这样的话后端接口获取参数,直接从HttpServletRequest  取出map  ,当然也可以直接取出文件内容。
因为HttpServletRequest中包含了拦截其中放入其中的参数  和 文件内容。

 

package com.ay.voipwork.interceptor;
//import org.springframework.data.redis.connection.lettuce;
import com.ay.voipwork.until.CommontMethod;
import com.ay.voipwork.until.RestUtil;
import com.ay.voipwork.until.SystemCode;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.*;

@Component
public class RequestParamInterceptor implements HandlerInterceptor {
    private static Logger log = LoggerFactory.getLogger( RequestParamInterceptor.class );
    @Autowired
    ObjectMapper objectMapper;


   private List<String> parseMutipartFile(MultipartFile multipartFile){

       InputStream inputStream = null;
       List<String> fileContentList=new ArrayList<>(  );
       try {
           inputStream = multipartFile.getInputStream();
           BufferedReader bufferedReader = new BufferedReader( new InputStreamReader( inputStream ) );
           String s="";
           while ((s=bufferedReader.readLine())!=null){
              fileContentList.add( s );

           }
       } catch (IOException e) {
           e.printStackTrace();
       }
     return fileContentList;
   }



    /*
  * @author pg
  * @date  2019-11-21 13:56
  * 无论是 post 还是 get请求统一获取参数封装成 map发给control 让controller获取参数更加的方便
 */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
       
        Map<String, Object> paramMap = new HashMap<>();
        String method = request.getMethod();//获取请求方式
        ServletInputStream servletInputStream = request.getInputStream();


        if ("POST".equals( method ) || "PUT".equals( method )) {
           //若是普通http请求
            if (!(request instanceof MultipartHttpServletRequest)){
                String jsonStr = inputStreamToString( servletInputStream );//json字符串
                if (!isJson( jsonStr ) || jsonStr.length() < 1) {//判断是否是json
                    if (!isJson( jsonStr ) || jsonStr.length() < 1) {//判断是否是json
                        RestUtil.response( response, SystemCode.ParameterValidError.getCode(), SystemCode.ParameterValidError.getMessage() + "不是正常的json参数" );
                        return false;
                    }
                }
                paramMap = CommontMethod.stringToJson( jsonStr );//传入的参数
                log.info( "POST:  paraMap:  " + paramMap );
            }
            //若是文件上传请求
            if (request instanceof MultipartHttpServletRequest){

                MultipartHttpServletRequest multipartHttpServletRequest = (MultipartHttpServletRequest)request;
                System.out.println("type:  "+multipartHttpServletRequest.getContentType());
                MultipartFile multipartFile = multipartHttpServletRequest.getFile( "file" );
                List<String> phoneList =  parseMutipartFile( multipartFile );
                Enumeration enu = request.getParameterNames();
                while (enu.hasMoreElements()) {
                    String paraName = (String) enu.nextElement();
                    paramMap.put( paraName, request.getParameter( paraName ) );
                }
                request.setAttribute( "param_json",paramMap );
                request.setAttribute( "phoneList",phoneList );
//后端获取   request.getAttribute("param_json") ; request.getAttribute("phoneList")

                log.info( "POST:  paraMap:  " + paramMap );
                log.info( "正在请求电话号码请求接口!" );
                log.info( "phonesList :"+phoneList );
            }




        } else if ("GET".equals( method )) {
            Enumeration enu = request.getParameterNames();
            while (enu.hasMoreElements()) {
                String paraName = (String) enu.nextElement();
                paramMap.put( paraName, request.getParameter( paraName ) );
            }
            log.info( "GET:  paraMap:  " + paramMap );
        }
        request.setAttribute( "param_json", paramMap );
        return true;
    }

    /**
     * 判断是否是json结构
     */
    private boolean isJson(String jsonInString) {
        try {
            final ObjectMapper mapper = new ObjectMapper();
            mapper.readTree( jsonInString );
            return true;
        } catch (IOException e) {
            return false;
        }
    }


    private String inputStreamToString(InputStream is) {
        ByteArrayOutputStream result = new ByteArrayOutputStream();
        byte[] buffer = new byte[1024];
        int length;
        String str = "";
        try {
            while ((length = is.read( buffer )) != -1) {
                result.write( buffer, 0, length );
            }
            str = result.toString( StandardCharsets.UTF_8.name() );
            return str;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return str;
    }
}

2.注册拦截器

 

package com.ay.voipwork.interceptor;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class RequestParamInterceptorConf implements WebMvcConfigurer {
    @Autowired
    RequestParamInterceptor requestParamInterceptor;
    @Autowired
    RequestFrequenceInterceptor frequenceInterceptor;
    @Override
    public void addInterceptors(InterceptorRegistry registry){
        // 多个拦截器组成一个拦截器链
        // addPathPatterns 用于添加拦截规则
        // excludePathPatterns 用户排除拦截
        // TokenInterceptor()为自己定义的拦截器
        registry.addInterceptor(requestParamInterceptor).addPathPatterns("/**").excludePathPatterns("/error");
    }
}

 

总结:如果你有什么好的处理方式,不妨评论。

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 不是的,Spring Boot拦截器不仅可以拦截URL,还可以拦截请求的其他部分,例如请求参数、请求头等。它允许您在请求进入控制器之前进行拦截,以实现特定的预处理任务。如果您需要在请求到达控制器之前对请求进行特定的处理,可以使用Spring Boot拦截器来实现。 ### 回答2: Spring Boot拦截器可以拦截除了URL之外的许多其他内容。拦截器是在请求被处理之前或之后对请求进行处理的一种机制。一般来说,拦截器可以拦截以下内容: 1. URL路径:拦截器最常用于拦截指定的URL路径。通过配置拦截器的路径模式,可以限制只有满足特定路径规则的请求才会被拦截。 2. 请求方法:拦截器可以针对特定的HTTP请求方法进行拦截,如GET、POST、PUT等。这样可以根据不同的请求方法来执行特定的处理逻辑。 3. Session:拦截器可以用于检查和处理会话信息。通过访问请求的会话,拦截器可以验证用户的身份,添加或删除会话属性等。 4. 参数:拦截器也可以根据请求的参数来进行拦截。可以通过访问请求的参数,拦截器可以验证参数的有效性,进行参数的转换等。 5. 请求头:拦截器可以检查和处理请求头信息,如验证请求头中的授权信息,判断请求头中的内容类型等。 总之,Spring Boot拦截器不仅限于拦截URL,还可以根据请求的不同方面和内容进行拦截和处理。不同的拦截器可以针对不同的需求进行配置和使用,以实现更灵活和精确的请求拦截和处理机制。 ### 回答3: Spring Boot拦截器既可以拦截URL,也可以拦截其他类型的请求。拦截器是在处理请求的过程中进行拦截并执行某些操作的组件。通过实现Spring的HandlerInterceptor接口,可以自定义拦截器并进行相关配置。拦截器在请求到达控制器之前执行预处理操作,然后在控制器处理请求之后执行后处理操作。 拦截器可以拦截的内容包括: 1. URL路径:可以通过配置拦截器的路径来拦截指定的URL请求。 2. 请求方法:可以拦截指定的HTTP请求方法,如GET、POST等。 3. 请求参数:可以通过指定请求参数的条件来拦截请求。 4. 请求头:可以拦截指定的请求头信息。 5. Session信息:可以拦截对Session的访问。 6. 异常情况:可以在发生异常时拦截请求并进行相应处理。 7. 其他:可以在拦截器中自定义一些其他的拦截规则,如IP黑名单、权限验证等。 需要注意的是,拦截器只能对请求进行拦截和处理,具体的业务逻辑还是需要在控制器中完成。拦截器可以用于日志记录、权限验证、参数验证等场景,能够提高代码的复用性和安全性。但是,拦截器并不能替代过滤器(Filter),过滤器是在请求到达Servlet之前进行拦截和处理的组件,可以对请求和响应进行一些通用的处理操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我先森

鼓励一个吧,哈哈

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值