zoukankan      html  css  js  c++  java
  • shiro 集成 JWT 自动获取token对应的用户信息

    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.shopxx.entity.User;
    import net.shopxx.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);//从头部获取JWT字符串信息
            if(logger.isDebugEnabled()) {
                logger.debug("=========>tokenHeader {}", tokenHeader);    
            }
            if(StringUtils.isNotBlank(tokenHeader)) {
                Long userId = JwtTokenUtil.getUserIdFromToken(tokenHeader);//解码JWT,获得userid
                if(userId!=null) {
                    if (logger.isDebugEnabled()) {
                        logger.debug("getUserIdFromToken userId {}", userId);
                    }
                    
                    User auser=userService.find(userId);//根据userID获取用户信息
                    if(auser!=null) {
                        PrincipalCollection principals = new SimplePrincipalCollection(auser, "authorizingRealm");//拼装shiro用户信息
                        Builder builder = new WebSubject.Builder(request, response);
                        builder.principals(principals);
                        builder.authenticated(true);
                        WebSubject subject = builder.buildWebSubject();
                        ThreadContext.bind(subject);//塞入容器,统一调用
                    }
                    
                }
            }
            chain.doFilter(request, response);
        }
    
    }
        public  @ResponseBody Map<String ,Object> complete(@CurrentUser User auser){
            
            if(auser==null) {
                logger.debug("=======auser==null======");
                return null;
            }
            
            Long userId=auser.getId();
            logger.debug("======userId {}=====",userId);
    
    }
  • 相关阅读:
    分享到微信时如何自定义文字描述和图片
    Book Review: PowerShell 3.0 Advanced Administration Handbook
    ListView setOnItemClickListener无效原因分析
    Android 自定义通用的loadingview
    Android Studio快速开发之道
    Android 轻松实现仿淘宝地区选择
    Android自定义View4——统计图View
    Android打造属于自己的数据库操作类。
    一起来学习android自定义控件3——边缘凹凸的View
    使用Intellij IDEA搭建Ext JsMVC web项目
  • 原文地址:https://www.cnblogs.com/nanahome/p/7819206.html
Copyright © 2011-2022 走看看