基于SpringBoot实现用户身份验证工具

作者:玩具熊猫 时间:2022-05-08 18:37:29 

session失效时间

 在Tomcat上,session的默认有效时间是30分钟。也可以通过配置文件修改session的有效时间。

 1)修改web.xml


<!-- 设置session失效,单位分 -->
<session-config>
 <session-timeout>1</session-timeout>
</session-config>


2).yml文件




server.session.cookie.http-only= #是否开启HttpOnly
server.session.timeout = #会话超时(秒)


使用过滤器获取session进行身份验证(未全部测试,慎用)


1)新建Filter




import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.web.servlet.ServletComponentScan;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Component;
import org.springframework.web.context.support.WebApplicationContextUtils;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
@Component
@ServletComponentScan//让@WebFilter起作用
@WebFilter(urlPatterns = "/*")
public class MyFilter implements Filter{
 @Autowired
 private SessionKeyConfigProperties sessionKeyConfigProperties;
 @Override
 public void init(FilterConfig filterConfig) throws ServletException {
 }
 @Override
 public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
     throws IOException, ServletException {
   HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
   System.out.println(sessionKeyConfigProperties.getUserTypeKey());
   //通过session获取身份信息
   AuthenticationUtil authenticationUtil = new AuthenticationUtil(sessionKeyConfigProperties);
   UserTypeEnum userType = authenticationUtil.getUserAuthentication(httpServletRequest.getSession());
   //进行认证
   //认证失败
   if(userType == null){
     //...
   }
   //用户不是管理员
   if(userType != UserTypeEnum.ADMIN){
     //...
   }
   filterChain.doFilter(servletRequest,servletResponse);
 }
 @Override
 public void destroy() {
 }
}

细心的读者会发现我用了AuthenticationUtil,这是为了将读写用户身份认证信息的功能分离而设计的工具类  2)AuthenticationUtil类


import org.apache.shiro.web.session.HttpServletSession;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
public class AuthenticationUtil {
 private SessionKeyConfigProperties configProperties;
 public AuthenticationUtil(SessionKeyConfigProperties configProperties) {
   this.configProperties = configProperties;
 }
 /**
  * 从session中获取用户的身份类型
  * @param session
  * @return 身份类型
  */
 public UserTypeEnum getUserAuthentication(HttpSession session){
   //获取session中的用户信息记录
   Object userType = session.getAttribute(configProperties.getUserTypeKey());
   //获取session中记录的用户类型
   if(userType != null && userType instanceof UserTypeEnum) {
     return (UserTypeEnum)userType;
   }
   return null;
 }
 /**
  * 将用户的身份写入session中
  * @param session
  * @param userType
  */
 public void setUserAuthentication(HttpSession session,UserTypeEnum userType){
   session.setAttribute(configProperties.getUserTypeKey(),userType);
 }
}

3)配置文件SessiionKeyConfig.properties

user_type_key = userTypeKey 

4)配置读取文件SessionKeyConfigProperties.class


import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Component;
@Configuration
@PropertySource("classpath:config/SessiionKeyConfig.properties")
@Component
public class SessionKeyConfigProperties {
 @Value("${user_type_key}")
 private String userTypeKey;
 public String getUserTypeKey() {
   return userTypeKey;
 }
 public void setUserTypeKey(String userTypeKey) {
   this.userTypeKey = userTypeKey;
 }
}

5)Enum类


public enum UserTypeEnum {
 ADMIN,
 USER
}

注:本文删除了一些package信息及部分import信息。Enum类和配置类的内容请根据项目需求及数据字典自行修改。

总结

以上所述是小编给大家介绍的基于SpringBoot实现用户身份验证工具网站的支持!

来源:https://blog.csdn.net/qq_34964570/article/details/79163562

标签:springboot,用户身份验证
0
投稿

猜你喜欢

  • 分别在Groovy和Java中创建并初始化映射的不同分析

    2023-11-26 08:15:42
  • Android按钮单击事件的四种常用写法总结

    2023-07-15 09:05:18
  • Springboot2.x+ShardingSphere实现分库分表的示例代码

    2023-11-26 01:34:07
  • 详解Java的TCP/IP编程学习--基于定界符的成帧

    2023-11-23 03:02:32
  • 简单了解4种分布式session解决方案

    2023-08-09 11:45:49
  • java使用静态关键字实现单例模式

    2023-11-29 13:37:33
  • 不规范使用ThreadLocal导致bug分析解决

    2023-11-24 20:03:59
  • Java中IO流文件读取、写入和复制的实例

    2023-08-12 03:23:29
  • IDEA部署JavaWeb项目到Tomcat服务器的方法

    2023-11-02 23:21:22
  • Java面试题冲刺第五天--基础篇2

    2023-10-07 13:17:04
  • 详解java WebSocket的实现以及Spring WebSocket

    2023-11-24 13:16:25
  • ArrayList详解和使用示例_动力节点Java学院整理

    2023-08-05 13:15:41
  • Java实现批量向mysql写入数据的方法

    2023-11-05 20:51:21
  • 浅谈java中Math.random()与java.util.random()的区别

    2023-11-26 16:37:16
  • Java Thread之Sleep()使用方法及总结

    2023-11-16 10:38:35
  • IDEA不编译除了.java之外的文件的解决办法(推荐)

    2023-09-16 15:50:44
  • 关于@ApiImplicitParams、ApiImplicitParam的使用说明

    2023-11-09 10:49:34
  • sms4j 2.0 全新来袭功能的调整及maven变化详解

    2023-11-05 00:31:51
  • Intellij IDEA + Android SDK + Genymotion Emulator打造最佳Android开发环境

    2023-06-17 06:47:11
  • Java常用类String的面试题汇总(java面试题)

    2023-11-23 20:40:45
  • asp之家 软件编程 m.aspxhome.com