| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | package com.ruoyi.common.utils;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import org.springframework.security.core.Authentication;
 | 
					
						
							|  |  |  | import org.springframework.security.core.context.SecurityContextHolder;
 | 
					
						
							|  |  |  | import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
 | 
					
						
							|  |  |  | import com.ruoyi.common.constant.HttpStatus;
 | 
					
						
							| 
									
										
										
										
											2020-07-19 10:25:40 +08:00
										 |  |  | import com.ruoyi.common.core.domain.model.LoginUser;
 | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | import com.ruoyi.common.exception.CustomException;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * 安全服务工具类
 | 
					
						
							|  |  |  |  * 
 | 
					
						
							|  |  |  |  * @author ruoyi
 | 
					
						
							|  |  |  |  */
 | 
					
						
							|  |  |  | public class SecurityUtils
 | 
					
						
							|  |  |  | {
 | 
					
						
							| 
									
										
										
										
											2021-08-08 19:12:12 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 用户ID
 | 
					
						
							|  |  |  |      **/
 | 
					
						
							|  |  |  |     public static Long getUserId()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         try
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             return getLoginUser().getUserId();
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |         catch (Exception e)
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             throw new CustomException("获取用户ID异常", HttpStatus.UNAUTHORIZED);
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 获取部门ID
 | 
					
						
							|  |  |  |      **/
 | 
					
						
							|  |  |  |     public static Long getDeptId()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         try
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             return getLoginUser().getDeptId();
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |         catch (Exception e)
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             throw new CustomException("获取部门ID异常", HttpStatus.UNAUTHORIZED);
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  |     
 | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 获取用户账户
 | 
					
						
							|  |  |  |      **/
 | 
					
						
							|  |  |  |     public static String getUsername()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         try
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             return getLoginUser().getUsername();
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |         catch (Exception e)
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             throw new CustomException("获取用户账户异常", HttpStatus.UNAUTHORIZED);
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 获取用户
 | 
					
						
							|  |  |  |      **/
 | 
					
						
							|  |  |  |     public static LoginUser getLoginUser()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         try
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             return (LoginUser) getAuthentication().getPrincipal();
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |         catch (Exception e)
 | 
					
						
							|  |  |  |         {
 | 
					
						
							|  |  |  |             throw new CustomException("获取用户信息异常", HttpStatus.UNAUTHORIZED);
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 获取Authentication
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public static Authentication getAuthentication()
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         return SecurityContextHolder.getContext().getAuthentication();
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 生成BCryptPasswordEncoder密码
 | 
					
						
							|  |  |  |      *
 | 
					
						
							|  |  |  |      * @param password 密码
 | 
					
						
							|  |  |  |      * @return 加密字符串
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public static String encryptPassword(String password)
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
 | 
					
						
							|  |  |  |         return passwordEncoder.encode(password);
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 判断密码是否相同
 | 
					
						
							|  |  |  |      *
 | 
					
						
							|  |  |  |      * @param rawPassword 真实密码
 | 
					
						
							|  |  |  |      * @param encodedPassword 加密后字符
 | 
					
						
							|  |  |  |      * @return 结果
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public static boolean matchesPassword(String rawPassword, String encodedPassword)
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
 | 
					
						
							|  |  |  |         return passwordEncoder.matches(rawPassword, encodedPassword);
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * 是否为管理员
 | 
					
						
							|  |  |  |      * 
 | 
					
						
							|  |  |  |      * @param userId 用户ID
 | 
					
						
							|  |  |  |      * @return 结果
 | 
					
						
							|  |  |  |      */
 | 
					
						
							|  |  |  |     public static boolean isAdmin(Long userId)
 | 
					
						
							|  |  |  |     {
 | 
					
						
							|  |  |  |         return userId != null && 1L == userId;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 |