前言
由于接口需要有个token认证,需要放在cookie中,但是这个token中含有= ,+, / 等符号,存储在前端导致了乱码。所以想了个办法在网关这层将cookie 在解码一下再放进去。
cookie的修改
原本我是采用这种方式 new一个新的MultiValueMap 将修改好的cookie放入。
之后在通过public MultiValueMap<String, HttpCookie> getCookies() 这个方法
但是没有效果不知道为什么。(有大佬知道吗)
ServerHttpRequest oldRequest= exchange.getRequest();
MultiValueMap<String, HttpCookie> cookieMultiValueMap = oldRequest.getCookies();
HttpCookie cookie = cookieMultiValueMap.getFirst("LtpaToken");
MultiValueMap<String, HttpCookie> NewCookieMultiValueMap = new LinkedMultiValueMap<>();
NewCookieMultiValueMap.add("LtpaToken",cookie);
newRequest = new ServerHttpRequestDecorator(newRequest) {
public MultiValueMap<String, HttpCookie> getCookies() {
return NewCookieMultiValueMap;
}
};
没办法采用修改header方法
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
ServerHttpRequest oldRequest= exchange.getRequest();
MultiValueMap<String, HttpCookie> cookieMultiValueMap = oldRequest.getCookies();
HttpCookie cookie = cookieMultiValueMap.getFirst("LtpaToken");
if(cookie != null){
String cookieValue = URLDecoder.decode(cookie.getValue());
//把request重新包装,继续传递
URI uri = oldRequest.getURI();
ServerHttpRequest newRequest = oldRequest.mutate().uri(uri).build();
// 定义新的消息头
HttpHeaders headers = new HttpHeaders();
headers.putAll(exchange.getRequest().getHeaders());
headers.remove(HttpHeaders.COOKIE);
headers.set(HttpHeaders.COOKIE, "LtpaToken="+cookieValue);
newRequest = new ServerHttpRequestDecorator(newRequest) {
@Override
public HttpHeaders getHeaders() {
return headers;
}
};
return chain.filter(exchange.mutate().request(newRequest).build());
}else{
return chain.filter(exchange);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由半码博客整理,本文链接:https://www.bmabk.com/index.php/post/15319.html