关于cookie:Spring-RestTemplate-透传Cookie

42次阅读

共计 801 个字符,预计需要花费 3 分钟才能阅读完成。

前端页面申请服务 A,服务 A 再调用服务 B,其中服务 B 须要登陆。那么服务 A 如何可能把登陆信息传递给服务 B 呢?
首选要满足第一点:零碎 A、B 做了 SSO 登陆解决。举例:A 服务可能解决的登陆 Session,B 服务也同样可能解决。

public Object sendPostWithCookieObject(String url, Map<String, Object> params) {HttpHeaders requestHeaders = new HttpHeaders();
        requestHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8);
        HttpServletRequest request = getRequest();
        if (request != null) {Cookie[] cookies = request.getCookies();
            if (cookies != null) {List<String> cookieList = Arrays.stream(cookies)
                        .map(obj -> obj.getName() + "=" + obj.getValue())
                        .collect(Collectors.toList());
                requestHeaders.put(HttpHeaders.COOKIE, cookieList);
            }
        }
        //body
        HttpEntity<Map<String, Object>> requestEntity = new HttpEntity<>(params, requestHeaders);

        Object result = restTemplate.postForObject(url, requestEntity, Object.class);

        return result;
    }

A 服务调用 B 服务的时候应用这个办法,能够把 cookie 传递给 B 服务,B 服务可能从 cookie 中获取申请的登陆信息。

正文完
 0