Spring Cloud Gateway -- cookie添加修改

博客围绕接口token认证需存于cookie展开。因token含特殊符号,存于前端导致乱码,于是想在网关层对cookie解码后再存储。修改cookie时,先尝试新建MultiValueMap放入修改后的cookie,调用getCookies()方法却无效,最后只能采用修改header方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring Cloud Gateway -- 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);
        }
    }
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值