spring 统一处理http request请求返回数据,返回加密信息等

在客户端发http请求的时候,如何统一处理对返回信息加密等操作?方法如下:

 

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.TimeZone;

import org.springframework.core.MethodParameter;
import org.springframework.http.MediaType;
import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice;

import com.fasterxml.jackson.databind.ObjectMapper;

@SuppressWarnings("rawtypes")
@ControllerAdvice
public class MyBodyAdvice implements ResponseBodyAdvice{
    /**
     * 解析出url参数中的键值对
     * 如 "index.jsp?Action=del&id=123",解析出Action:del,id:123存入map中
     * @param URL  url地址
     * @return  url请求参数部分
     */
    public Map<String, String> urlRequest(String URL) {
        Map<String, String> mapRequest = new HashMap<String, String>();
        String[] arrSplit = null;
        String strUrlParam = truncateUrlPage(URL);
        if (strUrlParam == null) {
            return mapRequest;
        }
        // 每个键值为一组
        arrSplit = strUrlParam.split("[&]");
        for (String strSplit : arrSplit) {
            String[] arrSplitEqual = null;
            arrSplitEqual = strSplit.split("[=]");
            // 解析出键值
            if (arrSplitEqual.length > 1) 
                // 正确解析
                mapRequest.put(arrSplitEqual[0], arrSplitEqual[1]);
            else {
                if (arrSplitEqual[0] != "") 
                    // 只有参数没有值,不加入
                    mapRequest.put(arrSplitEqual[0], "");
            }
        }
        return mapRequest;
    }
    
    private String truncateUrlPage(String strURL) {
        String strAllParam = null;
        String[] arrSplit = null;
        strURL = strURL.trim().toLowerCase();

        arrSplit = strURL.split("[?]");
        if (strURL.length() > 1) {
            if (arrSplit.length > 1) 
                if (arrSplit[1] != null) 
                    strAllParam = arrSplit[1];    
        }
        return strAllParam;
    }
    
    //request请求结果返回前处理方法

  //obj 是请求返回的数据,主要就是修改它了
    @Override
    public Object beforeBodyWrite(Object obj, MethodParameter arg1, MediaType arg2, Class arg3, ServerHttpRequest request,     ServerHttpResponse response) {
        try{
            //处理post请求参数
            if(request.getBody()!=null && request.getBody().read()>1 && request.getBody().toString()!=null ){
              
                /*String readline ="";
                StringBuffer sb = new StringBuffer();
                BufferedReader br = new BufferedReader(new InputStreamReader(request.getBody()));
                while (br.ready())
                {
                    readline = br.readLine();
                    sb.append(readline);
                }
                br.close();*/
                //System.out.println("-------------   request body is : "+sb.toString());
            }else{//处理get请求
                Map<String,String> mapstr = urlRequest(request.getURI().toString());//拿到路径中的参数信息
                System.out.println("-----request get url is----"+request.getURI());
              // 。。。。。。处理你的业务逻辑
                return obj;
            }

            
        }catch(Exception e){
            e.printStackTrace();
            return obj;
        }
        return obj;
    }
    
    
    @Override
    public boolean supports(MethodParameter arg0, Class arg1) {
        // TODO Auto-generated method stub
        return true;//返回true 表示继续执行下去
    }
 
}

 

需要引入:<dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-webmvc</artifactId>
          <version>4.1.9.RELEASE</version>
        </dependency> 

转载于:https://my.oschina.net/adwangxiao/blog/728006

Spring Boot中,可以通过实现HandlerInterceptor接口的preHandle()方法来处理加密后重写request的问题。根据提供的引用内容,有两种方式可以实现。 第一种方式是通过在DecryptInterceptor的preHandle()方法中手动模拟解密并比对参数,然后将解密后的参数重新赋值给request。具体代码如下所示: ```java @Slf4j public class DecryptInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (request instanceof DecryptServletRequestWrapper) { DecryptServletRequestWrapper requestWrapper = (DecryptServletRequestWrapper) request; Map<String, Object> requestBody = requestWrapper.getRequestBody(); // 这里可以处理解密逻辑,我这里直接赋值了,就不解密了 requestBody.put("name", "yichen"); requestBody.put("address", "海底两万里"); // 对比结果 requestBody.put("age", 18); DecryptServletRequestWrapper.printMap(requestBody); } return true; } } ``` 在这段代码中,我们可以看到在preHandle()方法中,首先判断request是否是DecryptServletRequestWrapper类型,如果是,则获取请求体的参数,并进行解密逻辑。在这个例子中,为了简化,直接给name和address字段赋值,并添加了age字段。最后,我们将修改后的参数重新赋值给request。 另一种方式是在LoginInterceptor的preHandle()方法中实现解密逻辑。具体代码如下所示: ```java @Component public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //获取请求头中的token String token = request.getHeader("token"); //判断token是否为空,如果为空也代表未登录 提醒重新登录(401) if (!StringUtils.hasText(token)) { response.sendError(HttpServletResponse.SC_UNAUTHORIZED); return false; } //解析token看看是否成功 try { Claims claims = JwtUtil.parseJWT(token); String subject = claims.getSubject(); System.out.println(subject); //在这里进行解密逻辑并重写request的参数 //... } catch (Exception e) { e.printStackTrace(); //如果解析过程中没有出现异常说明是登录状态 //如果出现了异常,说明未登录,提醒重新登录(401) response.sendError(HttpServletResponse.SC_UNAUTHORIZED); return false; } return true; } } ``` 在这段代码中,我们可以看到在preHandle()方法中,首先获取请求头中的token。然后通过解析token来验证用户的登录状态。在这个例子中,我们可以在try块中进行解密逻辑并根据解密后的参数重写request的参数。 综上所述,根据不同的情况可以在不同的Interceptor中实现解密逻辑并重写request的参数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [springboot处理数据解密](https://blog.csdn.net/weixin_42241455/article/details/123909299)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [SpringBoot拦截器登录处理+异常统一处理+自定义注解](https://blog.csdn.net/qq_41627017/article/details/126445460)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值