zoukankan      html  css  js  c++  java
  • JwtAuthenticationTokenFilter 实现shiro 利用 token 信息完成令牌登录

    package net.filter.jwt;
    
    import java.io.IOException;
    
    import javax.servlet.FilterChain;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import org.apache.commons.lang.StringUtils;
    import org.apache.shiro.subject.PrincipalCollection;
    import org.apache.shiro.subject.SimplePrincipalCollection;
    import org.apache.shiro.util.ThreadContext;
    import org.apache.shiro.web.subject.WebSubject;
    import org.apache.shiro.web.subject.WebSubject.Builder;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.filter.OncePerRequestFilter;
    
    import net.entity.User;
    import net.service.UserService;
    
    /**
     * 过滤请求头部信息,如果有,就自动登录 http://blog.csdn.net/qi923701/article/details/75007813
     * 
     * @author wutao
     * @date 2017年11月11日 下午3:09:51
     */
    public class JwtAuthenticationTokenFilter extends OncePerRequestFilter {
    
        private static final Logger logger = LoggerFactory.getLogger(JwtAuthenticationTokenFilter.class);
    
        @Autowired
        private UserService userService;
    
        @Override
        protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain)
                throws ServletException, IOException {
            String tokenHeader = request.getHeader(JwtTokenUtil.AUTH_TOKEN);
            if (StringUtils.isNotBlank(tokenHeader)) {
                Long userId = JwtTokenUtil.getUserIdFromToken(tokenHeader);
                if (userId != null) {
                    if (logger.isDebugEnabled()) {
                        logger.debug("getUserIdFromToken userId {}", userId);
                    }
    
                    User auser = userService.find(userId);
                    if (auser != null) {
                        PrincipalCollection principals = new SimplePrincipalCollection(auser, "authorizingRealm");
                        Builder builder = new WebSubject.Builder(request, response);
                        builder.principals(principals);
                        builder.authenticated(true);
                        WebSubject subject = builder.buildWebSubject();
                        ThreadContext.bind(subject);
                    }
    
                }
            }
            chain.doFilter(request, response);
        }
    
    }
  • 相关阅读:
    Mego(02)
    Mego(01)
    ThoughtWorks(中国)程序员读书雷达 —— 书籍下载整理
    Spring源码编译一次性通过&遇到的坑解决方法
    Elasticsearch怎么修改索引字段类型?
    Flume 自定义拦截器 多行读取日志+截断
    用Hibernate框架把hql生成可执行的sql语句-Oracle方言
    深入浅出SQL Server中的死锁 [转于CareySon]
    第一次迭代随笔
    结对编程代码分析
  • 原文地址:https://www.cnblogs.com/nanahome/p/7894880.html
Copyright © 2011-2022 走看看