后端使用springcloudgateway路由转发后前端的cookie为undefined!

本地测试的时候,前端,后端,网关都在自己的电脑上,一切都正常,但当把模块拆分在不同服务器部署时登录发生了异常:

部署视图

查看日志发现,token返回是正常的,只是存取cookie发生了问题,分析过后是cookie的domain问题:

cookie.set("aixuehub-token", data.data.token, {domain: 'localhost'})
cookie.get('aixuehub-token')

我在想是不是因为是网关转发的路由,这个localhost就是网关服务器的ip了,在我去掉domain,变为:

cookie.set("aixuehub-token", data.data.token)

 这样domain即使默认值当前域了,也就恢复正常了,对前端不是很了解,虽然问题解决了但是原理尚不清楚,望大佬看到了指点指点,哈哈哈.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Gateway是基于Spring Boot 2.x和Spring WebFlux实现的网关服务,提供统一的负载均衡和转发的功能。它支持多种由方式,比如URL径匹配、请求头匹配、请求参数匹配等等。 转发是Spring Cloud Gateway的一个重要功能,可以通过转发把来自客户端的请求转发到指定的目标服务。转发的过程中,网关会根据预定义的由规则来匹配请求,并选择合适的目标服务进行转发。 Spring Cloud Gateway的由规则可以通过配置文件或者编程方式进行定义。在配置文件中,可以使用YAML或者Properties格式来定义由规则。下面是一个YAML格式的由规则示例: ``` spring: cloud: gateway: routes: - id: my_route uri: http://localhost:8080 predicates: - Path=/my_service/** ``` 这个示例定义了一个名为my_route的由规则,它会把以/my_service开头的请求转发到http://localhost:8080。 除了Path,Spring Cloud Gateway还支持其他各种由方式,比如Header、Cookie、Method、Query等等。你可以根据自己的需求选择合适的由方式。 在转发过程中,Spring Cloud Gateway还可以实现负载均衡的功能。它可以根据定义的负载均衡策略来选择合适的目标服务。目前Spring Cloud Gateway支持的负载均衡策略有Round Robin、Weighted Response Time等等。 总之,Spring Cloud Gateway是一个非常强大的网关服务框架,它可以提供统一的负载均衡和转发的功能,并且支持多种由方式和负载均衡策略。如果你的微服务架构需要一个可靠的网关服务,Spring Cloud Gateway是一个非常不错的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值