温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-05-24 11:44:35 来源:亿速云 阅读:401 作者:小新 栏目:编程语言

这篇文章主要介绍基于SpringBoot怎么实现用户身份验证工具,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

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是什么

springboot一种全新的编程规范,其设计目的是用来简化新Spring应用的初始搭建以及开发过程,SpringBoot也是一个服务于框架的框架,服务范围是简化配置文件。

以上是“基于SpringBoot怎么实现用户身份验证工具”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI