我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Redis解决跨域存取Session问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Redis解决跨域存取Session问题

前言

vue3+SpringBoot做项目时,由于vue前端项目是在8080端口运行,而后端项目是在8081端口运行,前端通过跨域发送axIOS请求发送给后端的场景下,我以前在前后端不分离的情况下做项目登录功能做过滤器时,直接用Session就可以将用户登录的信息存到session中,过滤器只需要查看在拦截路径时对session做获取,获取成功则说明可以用户是登录成功的。也不会出现session存不进去的情况。

这次的前后端分离这个问题就出现了,下面就来解决这个问题。

一、遇到的情况

在登录controller中的login方法里,登录成功后将值存到session中

request.getSession().setAttribute("administrator",admin.getId());

但在页面中打开f12,点开应用会发现没有存储session的信息。

session中没有存入的值

这就是跨域带来的问题,后端服务器是8081端口,存session就存不到前端8080端口的session中。

二、解决问题

既然已经知道了问题,在我发现这个问题时(因为我Debug调试跟踪后端代码后发现确实执行了存session的动作,所以才会知道是跨域导致的问题)。我一开始就上网找材料,查找解决办法。搜到的大部分都是在分布式的情况下共享session问题。不太符合解决我当前遇到的问题。

查了一段时间资料后,我想到了Redis,想到了:存session、取session的过程,那能用session去存取数值,为什么不用Redis呢?这让我“如鱼得水“,在学习完Redis后还没想到Redis可以用来代替session干活,哈哈。所以我将用Redis解决问题的步骤代码分享给大家,学过Redis的应该是属于简单易懂的。

2.1 配置yml文件

在yml文件中配置Redis的基本信息。

Redis解决跨域存取Session问题

2.2 启动Redis

将Redis服务器打开

Redis解决跨域存取Session问题

2.3 代码编写

第一步:注入RedisTemplate

@Autowired
private RedisTemplate redisTemplate;

第二步:将登录成功的值存到Redis中

//6.登录成功,将员工id存入Redis并返回登录成功结果
redisTemplate.opsForValue().set("administrator",admin.getId());

第三步:在过滤器拦截路径后取Redis中的值。当然了,别忘了在过滤器类注入RedisTemplate。

//4-1.判断登录状态,如果已登录,则直接放行
        if(redisTemplate.opsForValue().get("administrator") != null){
            
            Long adminId = (Long) redisTemplate.opsForValue().get("administrator");
            BaseContext.setCurrentId(adminId);
            //放行
            filterChain.doFilter(request,response);
            return;
        }

三、效果演示

先打开Redis桌面管理查看值,在没有登录时是没有值的。如下图:

Redis解决跨域存取Session问题

启动项目后我们登录一下,查看Redis中是否有值。
登录成功,在拦截器开的情况下也会发送axios请求查询数据库数据。所以已经证明了。

Redis解决跨域存取Session问题

但我们还是看下存到Redis的值,如下图:

Redis解决跨域存取Session问题

可以看到,已经实现了这个功能。使用Redis代替了session起到的作用。所以拦截器自然也知道你是登录过的,才会让行让方法能够查询数据库将数据显示到页面去。

总结

到这里使用Redis就解决了Session存取存在的跨域问题,也不叫解决session的跨域问题吧,只是换了个思路解决了同样的问题而已。我相信session也是可以解决这个问题的,应该是需要配置一些前端的代码等。我也不太清楚,但能用我们学习过的知识解决问题那不是更好吗!Redis用起来也很简单,也解决了当前的问题,我觉的是一个很不错的方法。

到此这篇关于Redis解决跨域存取Session问题的文章就介绍到这了,更多相关Redis跨域存取Session内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Redis解决跨域存取Session问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis解决跨域存取Session问题

目录前言一、遇到的情况二、解决问题2.1 配置yml文件2.2 启动Redis2.3 代码编写三、效果演示总结前言vue3+SpringBoot做项目时,由于vue前端项目是在8080端口运行,而后端项目是在8081端口运行,前端通过跨域
2023-04-12

PHP Session 跨域问题的解决方法

在前后端分离的开发中,跨域请求已成为常态。在处理跨域问题时,我们通常会涉及到 session 的使用和管理。然而,由于浏览器的同源策略限制,跨域情况下默认情况下无法共享 session。为了解决这个问题,我们需要采用一些技巧和方法来实现 s
2023-10-21

解决 PHP Session 跨域问题的开源解决方案

引言:在开发网站和应用程序时,我们常常会遇到跨域问题。其中一个常见的问题是 PHP Session 在跨域情况下无法正常使用。本文将介绍一种开源解决方案,帮助开发者解决 PHP Session 跨域问题,并提供具体的代码示例。一、背景和问题
2023-10-21

解决 PHP Session 跨域问题的最佳实践

随着互联网的发展,前后端分离的开发模式越来越普遍。在这种模式下,前端与后端可能部署在不同的域名下,这就导致了跨域问题的出现。而在使用 PHP 的过程中,跨域问题也涉及到 Session 的传递与管理。本文将介绍PHP中解决 Session
2023-10-21

解决 PHP Session 跨域问题的调试技巧

随着互联网的普及,Web 应用程序的开发越来越受到人们的关注。在开发 Web 应用程序时,经常会遇到跨域问题,例如在一个域名下的 PHP 程序需要访问另一个域名下的 Session 数据。在这篇文章中,我们将讨论如何解决 PHP Sessi
2023-10-21

session跨域后取不到值怎么解决

在跨域的情况下,浏览器默认不允许通过Cookie或者LocalStorage访问跨域的页面。因此,如果你在session跨域后无法获取值,可以尝试以下解决方案:1. 使用跨域资源共享(CORS):在服务端设置Access-Control-A
2023-08-15

PHP跨域问题如何解决

这篇文章主要讲解了“PHP跨域问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP跨域问题如何解决”吧!设置允许访问的域名:1、允许全部的域名访问header("Access-C
2023-07-05

react跨域问题怎么解决

在 React 中解决跨域问题通常有以下几种方法:1. 设置代理:在开发环境中,可以通过设置代理服务器来解决跨域问题。可以在 `package.json` 文件中的 `proxy` 字段中添加代理服务器的地址,例如:```"proxy":
2023-08-19

ajax跨域问题怎么解决

在Ajax请求中,由于浏览器的同源策略限制,如果请求的域名、端口或协议与当前页面不同,则会出现跨域问题,无法正常获取数据。以下是几种常见的解决跨域问题的方法:1、代理利用代理,通过后台获取其他域名下的内容,再将获得内容返回到前端,使其在同一
2023-05-13

JavaScript跨域问题怎么解决

这篇文章主要介绍了JavaScript跨域问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript跨域问题怎么解决文章都会有所收获,下面我们一起来看看吧。1.什么是跨域我们常常会在页面上使
2023-06-27

怎么解决SpringBoot跨域问题

这篇文章给大家分享的是有关怎么解决SpringBoot跨域问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。允许全部请求跨域许可的代码需要继承WebMvcConfigurerAdapter类。@Configura
2023-06-28

VUE如何解决跨域问题

这篇文章主要介绍“VUE如何解决跨域问题”,在日常操作中,相信很多人在VUE如何解决跨域问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VUE如何解决跨域问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-07-02

vue跨域问题怎么解决

1、可以在后端服务器中进行配置,允许指定的域名或IP地址访问后端API,这样就可以解决跨域问题。常用的方法是在服务器端添加CORS(Cross-Origin Resource Sharing)配置。2、可以在Vue应用的配置文件中设置代理,
2023-05-13

iframe如何解决跨域问题

iframe如何解决跨域问题,需要具体代码示例跨域问题是前端开发中常遇到的一个难题。由于浏览器的同源策略,页面中的JavaScript无法直接访问不同域名下的资源。解决这个问题有很多方法,其中之一便是使用iframe。什么是同源策略和跨域
iframe如何解决跨域问题
2024-02-22

编程热搜

目录