| package cn.stylefeng.roses.kernel.auth.api.loginuser; | 
|   | 
| import cn.hutool.core.util.StrUtil; | 
| import cn.stylefeng.roses.kernel.auth.api.exception.AuthException; | 
| import cn.stylefeng.roses.kernel.auth.api.exception.enums.AuthExceptionEnum; | 
| import cn.stylefeng.roses.kernel.auth.api.expander.AuthConfigExpander; | 
| import cn.stylefeng.roses.kernel.rule.util.HttpServletUtil; | 
|   | 
| import javax.servlet.http.Cookie; | 
| import javax.servlet.http.HttpServletRequest; | 
|   | 
| /** | 
|  * 获取当前登录用户的相关方法 | 
|  * | 
|  * @author fengshuonan | 
|  * @date 2021/9/28 17:46 | 
|  */ | 
| public class CommonLoginUserUtil { | 
|   | 
|     /** | 
|      * 获取当前登录用户Token | 
|      * | 
|      * @author fengshuonan | 
|      * @date 2021/9/28 17:46 | 
|      */ | 
|     public static String getToken() { | 
|   | 
|         // 获取当前http请求 | 
|         HttpServletRequest request = HttpServletUtil.getRequest(); | 
|   | 
|         // 1. 优先从param参数中获取token | 
|         String parameterToken = request.getParameter(AuthConfigExpander.getAuthTokenParamName()); | 
|   | 
|         // 不为空则直接返回param的token | 
|         if (StrUtil.isNotBlank(parameterToken)) { | 
|             return parameterToken; | 
|         } | 
|   | 
|         // 2. 从header中获取token | 
|         String authToken = request.getHeader(AuthConfigExpander.getAuthTokenHeaderName()); | 
|         if (StrUtil.isNotBlank(authToken)) { | 
|             return authToken; | 
|         } | 
|   | 
|         // 3. 从cookie中获取token | 
|         String sessionCookieName = AuthConfigExpander.getSessionCookieName(); | 
|         Cookie[] cookies = request.getCookies(); | 
|         if (cookies != null && cookies.length > 0) { | 
|             for (Cookie cookie : cookies) { | 
|   | 
|                 // 如果cookie有对应的值,并且不为空 | 
|                 if (sessionCookieName.equals(cookie.getName()) | 
|                         && StrUtil.isNotBlank(cookie.getValue())) { | 
|                     return cookie.getValue(); | 
|                 } | 
|             } | 
|         } | 
|   | 
|         // 获取不到token,直接告诉用户 | 
|         throw new AuthException(AuthExceptionEnum.TOKEN_GET_ERROR); | 
|     } | 
|   | 
| } |