我是靠谱客的博主 现实可乐,最近开发中收集的这篇文章主要介绍Spring Cloud Gateway -- cookie添加修改前言cookie的修改,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
Spring Cloud Gateway -- cookie添加修改
- 前言
- cookie的修改
前言
由于接口需要有个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);
}
}
最后
以上就是现实可乐为你收集整理的Spring Cloud Gateway -- cookie添加修改前言cookie的修改的全部内容,希望文章能够帮你解决Spring Cloud Gateway -- cookie添加修改前言cookie的修改所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复