前端页面请求服务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中获取请求的登陆信息。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。