热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

redis是干嘛的,springbootvue项目

springboot基于redis配置session共享项目环境配置pom.xml引入依赖application.properties配置Cookie序列化(高版本不需要)测试启


springboot依赖于部署pom.xml的application.properties来配置COOKIE序列化(高版本不需要),该部署基于redis构成session共享项目环境


项目环境


公司的项目年龄大,使用的springboot版本旧。 最新版本的springboot 2.6.0简化了配置。 springboot:1.5.22.RELEASE


jdk:8


是否要配置pom.xml部署依赖关系? XML版本=' 1.0 '编码=' utf-8 '? project xmlns=' http://maven.Apache.org/POM/4.0.0 ' xmlns : xsi=' http://www.w3.org/2001/XML方案ins ttins maven-4.0.0.xsd ' model版本4.0.0/modelversionparentgroupidorder groupidartifactidspring-boot-starter-parararer -另一个版本-- relativePath/! --- lookupparentfromrepository---parentgroupidcom.example/groupidartifactidmodule1/artifactidversion0.0.1- snapple namedescriptiondemoprojectforspringboot/descriptionpropertiesjava.1.8/Java . propertiesdependenciesdependencygroupidorg.spring framework.boot/groupidartifactidspring-boot-starter-web/artifaccer ependencydependencygroupidorg.spring framework.boot/groupidartifactidspring-boot-starter-test/artifactidscopetesest-- redis---- dependencygroupidorg.spring framework.boot/groupidartifactidspring-boot-star 部署art ification-spring-session---dependencygroupidorg.spring framework.session/groupidartifactidspring-sessiong 如果springboot使用较高版本,则可以使用相应的spring-session版本-- ver

sion>1.3.5.RELEASE org.springframework.boot spring-boot-maven-plugin application.properties配置

springboot 1.5.22.RELEASE版本配置如下:

server.port=8888server.context-path=/demo#必须指定session类型,否则报错spring.session.store-type=redisspring.redis.host=127.0.0.1spring.redis.port=6379

高版本配置如下:

server.port=8888server.servlet.context-path=/demo#设置COOKIE.path即可实现不同项目session共享server.servlet.session.COOKIE.path=/ spring.redis.host=127.0.0.1spring.redis.port=6379 COOKIE序列化(高版本不需要)

springboot 1.5.22.RELEASE版本,做完上述配置后,只能实现不同端口session共享,无法实现不同context-path不同端口的session共享。因此还需配置DomainNamePattern,实现不同项目session共享。

package com.example.module1.config;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.session.web.http.COOKIESerializer;import org.springframework.session.web.http.DefaultCOOKIESerializer;@Configurationpublic class SessionConfig {//设置COOKIE到期时间 public static final String COOKIE_MAX_AGE = "COOKIE.max-age"; /** * COOKIE序列化器 * @return */ @Bean public COOKIESerializer COOKIESerializer() { DefaultCOOKIEMaxAgeSerializer serializer = new DefaultCOOKIEMaxAgeSerializer(); serializer.setCOOKIEName("SESSION"); serializer.setCOOKIEPath("/"); serializer.setDomainNamePattern("^.+?\\.(\\w+\\.[a-z]+)$"); return serializer; }//内部类,动态设置COOKIE过期时间。如果不需要该功能,可删除。 public class DefaultCOOKIEMaxAgeSerializer extends DefaultCOOKIESerializer{/** * 覆盖回写COOKIE方法,设置COOKIE过期时间* session.isNew=true时调用*/ @Override public void writeCOOKIEValue(COOKIEValue COOKIEValue) { HttpServletRequest request = COOKIEValue.getRequest(); // 从request域读取到COOKIE的maxAge属性 Object attribute = request.getAttribute(COOKIE_MAX_AGE); if (attribute != null) { super.setCOOKIEMaxAge((int) attribute); }else{ super.setCOOKIEMaxAge(-1); } super.writeCOOKIEValue(COOKIEValue); } }} 测试 启动Redis

启动本地redis,过程略

启动nginx

启动本地nginx,过程略

SessionController

新建一个SessionController,内容如下:

package com.example.module1.controller;import org.springframework.beans.factory.annotation.Value;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;import javax.servlet.http.HttpSession;@Controller@RequestMapping("/session")public class SessionController { @Value("${server.port}") private String port; @ResponseBody @RequestMapping("/put") public String sessionShare(HttpServletRequest request){ HttpSession session = request.getSession(); session.setAttribute("session","test"); request.setAttribute(SessionConfig.COOKIE_MAX_AGE, 14*24*60*60); session.setMaxInactiveInterval(14*24*60*60); return port + ":" + session.getId(); } @ResponseBody @RequestMapping("get") public String getSession(HttpSession session){ return session.getId() + ":" + session.getAttribute("session")+",port:"+port; }} 启动项目

设置项目可重复启动,修改配置文件server.port和server.context-path。我分别启动了三个项目:

portcontext-path8888demo8889demo28890demo

浏览器查看session

可以看到三个项目的sessionid都是一样的,实现了session共享。


推荐阅读
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 本文将详细介绍通过CAS(Central Authentication Service)实现单点登录的原理和步骤。CAS由耶鲁大学开发,旨在为多应用系统提供统一的身份认证服务。文中不仅涵盖了CAS的基本架构,还提供了具体的配置实例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 本文详细介绍了JSP(Java Server Pages)的九大内置对象及其功能,探讨了JSP与Servlet之间的关系及差异,并提供了实际编码示例。此外,还讨论了网页开发中常见的编码转换问题以及JSP的两种页面跳转方式。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • npm run dev后报错 ... [详细]
  • 本文详细介绍了如何利用Go语言和WebSockets技术构建一个高效的实时聊天系统。随着网络应用的日益复杂化,实时交互成为了提升用户体验的关键要素之一。通过本指南,开发者可以学习到最新的技术和最佳实践。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • XWiki 数据模型开发指南
    本文档不仅介绍XWiki作为一个增强版的wiki引擎,还深入探讨了其数据模型,该模型可在用户界面层面被充分利用。借助其强大的脚本能力,XWiki的数据模型支持从简单的应用到复杂的系统构建,几乎无需直接接触XWiki的核心组件。 ... [详细]
  • Spring Security核心概念与应用实践
    本文详细介绍了Spring Security的核心机制,包括其作为一系列过滤器的工作原理,如何实现用户认证与授权,以及常见的配置方法和高级特性如CSRF防护。 ... [详细]
author-avatar
红昊子楽楽七_358
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有