页面嵌入iframe Cookie丢失问题解决

页面嵌入iframe Cookie丢失问题解决

遇到的问题

自身页面以iframe的形式嵌入三方页面中,双方域名不一致导致自身页面的cookie被某些浏览器拦截无法正常被保存到客户端

解决方案
  1. 后端将cookie以链接参数的形式带给前端
  2. 前端在请求接口的时候将cookie放在请求头(这里无法直接在请求头放置Cookie参数,需要使用一个新的参数来放置Cookie)
  3. 后端使用拦截器获获取请求头中Cookie副本解析后重新放置到Cookie中
后端部分实现示例代码
解析获取Response中的Cookie
// 从Response Header 中的 Set-Cookie解析
for (String cookie : response.getHeaders("Set-Cookie")) {
   
    cookie = cookie.split(";")[0];
    String[] split = cookie.split("=", 2);
    cookieMap.put(split[0], split[1]);
}
后端拦截器设置设置Coookie
@Component
@Order(1)
public class HeaderCookieFilter implements Filter {
   

    private static final Logger log = LoggerFactory.getLogger(HeaderCookieFilter.class);
    private final String HEADER_COOKIE_KEY = "identityKey";

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
   
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
   
        try {
   
            HttpServletRequestWrapper customRequest = (HttpServletRequestWrapper)request;
            JSONObject cookieInfo = check(request);
            //如果校验通过
            if(cookieInfo!=null) {
   
                Cookie[] cookies = new Cookie[cookieInfo.size()];
                // 修改cookie
                Iterator<String> iterator = cookieInfo.keySet().iterator();
                for (int i = 0; i < cookieInfo.keySet().size(); i++) {
   
                    String key = iterator.next();
                    String value = cookieInfo.getString(key);
                    Cookie cookie = new Cookie(key, value);
                    cookies[i] = cookie;
                }
                request = new CustomRequest(customRequest, cookies);
            }
        }catch (Exception e){
   
            log.error("header transfor cookie error",e);
        }
        chain.doFilter(request,response);
    }

    @Override
    public void destroy() {
   
    }

    private JSONObject check(ServletRequest request) throws UnsupportedEncodingException {
   
        HttpServletRequestWrapper customRequest = (HttpServletRequestWrapper)request;
        // 不存在identityKey请求头,直接跳过
        String allCookieStrEncode = customRequest.getHeader(HEADER_COOKIE_KEY);
        boolean hasHeaderCookie = StringUtils.isNotEmpty(allCookieStrEncode);
        if(!hasHeaderCookie){
   
            return null;
        }
        String cookieStr = URLDecoder.decode(allCookieStrEncode, CharEncoding.UTF_8);
        JSONObject cookieInfo = JSON.parseObject(cookieStr);
        return cookieInfo;
    }
    class CustomRequest extends HttpServletRequestWrapper {
   
        Cookie[] cookies;
        public CustomRequest(HttpServletRequest request, Cookie[] cookies) {
   
            super(request);
            this.cookies = cookies;
        }
        @Override
        public Cookie[] getCookies(){
   
            return cookies;
        }
    }
}

相关推荐

  1. 页面嵌入iframe Cookie丢失问题解决

    2024-01-18 13:10:03       37 阅读
  2. Spring Boot 项目请求参数丢失问题排查与解决

    2024-01-18 13:10:03       29 阅读
  3. 前端大额计算,真正解决js精度丢失问题

    2024-01-18 13:10:03       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-18 13:10:03       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-18 13:10:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-18 13:10:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-18 13:10:03       18 阅读

热门阅读

  1. python list.sort方法和内置函数sorted

    2024-01-18 13:10:03       34 阅读
  2. CTF - Web 干货

    2024-01-18 13:10:03       35 阅读
  3. jquery批量执行任务实时返回状态

    2024-01-18 13:10:03       37 阅读
  4. 006 Golang-channel-practice 并发打印字符串

    2024-01-18 13:10:03       33 阅读
  5. 【Android】ObjectBox Duplicate Class 错误分析

    2024-01-18 13:10:03       34 阅读
  6. WPF中Image控件Source的多种指定方式

    2024-01-18 13:10:03       31 阅读