spring boot response 写入头遇到的坑

7 篇文章 0 订阅
7 篇文章 0 订阅

 

一、需求背景

一个电商项目,后台修改了用户信息之后h5端由于有缓存,修改后的内容不能同步到。所以想到的一个办法就是当修改用户信息之后往redis写进去一个标记,该用户已经修改需要同步,然后下一次请求的时候把标记通过http response 头部返回一个标记告诉h5端需要重新加载用户信息。

二、服务端的坑

服务端用的是spring boot框架,一种办法是写一个拦截器,在拦截器的preHandle方法上写去头信息,记住这里不能在postHandle或者afterCompletion方法中写入头信息,因为执行到这2个方法的时候其实返回的信息已经处理发出去了,这里再写入头没有意义了。

这就是遇到的第一个坑。

还有一种办法就是写一个filter

package co.xxx.common.filter;

import co.xxx.utils.RedisUtil;
import co.xxx.utils.SecurityUtils;
import org.springframework.stereotype.Component;
import org.springframework.web.filter.OncePerRequestFilter;

import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
public class RefreshUserInfoFilter extends OncePerRequestFilter {
    @Override
    protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, FilterChain filterChain) throws ServletException, IOException {
        try{
            //该方法通常用于清理资源等工作
            int uid = SecurityUtils.getUserId() != null ?SecurityUtils.getUserId().intValue():0;
            Boolean flag = RedisUtil.get("user_change_flag_" + SecurityUtils.getUserId().intValue());

            if(uid == 0){
                return;
            }

            if (flag != null && flag){
                RedisUtil.set("user_change_flag_" + uid,false);
                httpServletResponse.addHeader("Access-Control-Allow-Headers","refresh-user-info");
                httpServletResponse.addHeader("Access-Control-Expose-Headers","refresh-user-info");
                httpServletResponse.addHeader("refresh-user-info","true");
            }
        }catch (Exception e){

        }
        filterChain.doFilter(httpServletRequest, httpServletResponse);
    }
}

三、客户端的坑

在上面的代码中有2行代码,如果没有这2行代码,前端(axios)是无法接受到refresh-user-info的头信息的 。服务端返回的时候就要添加。字面上理解就是允许头部变量吧。

httpServletResponse.addHeader("Access-Control-Allow-Headers","refresh-user-info");
httpServletResponse.addHeader("Access-Control-Expose-Headers","refresh-user-info");

四、客户端代码

客户端的代码就不贴出来了 ,就是拦截所有的请求看看有无refresh-user-info头信息 ,有的话重新加载下用户信息。

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值