package com.iailab.module.ansteel.util;
|
|
import com.iailab.framework.security.core.LoginUser;
|
import org.springframework.lang.Nullable;
|
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
|
import org.springframework.security.core.Authentication;
|
import org.springframework.security.core.context.SecurityContext;
|
import org.springframework.security.core.context.SecurityContextHolder;
|
import org.springframework.security.web.authentication.WebAuthenticationDetailsSource;
|
import org.springframework.util.StringUtils;
|
|
import javax.servlet.http.HttpServletRequest;
|
import java.util.Collections;
|
|
/**
|
* 安全服务工具类
|
*
|
* @author 芋道源码
|
*/
|
public class SecurityUtils {
|
|
public static final String AUTHORIZATION_BEARER = "Bearer";
|
|
private SecurityUtils() {}
|
|
/**
|
* 从请求中,获得认证 Token
|
*
|
* @param request 请求
|
* @param header 认证 Token 对应的 Header 名字
|
* @return 认证 Token
|
*/
|
public static String obtainAuthorization(HttpServletRequest request, String header) {
|
String authorization = request.getHeader(header);
|
if (!StringUtils.hasText(authorization)) {
|
return null;
|
}
|
int index = authorization.indexOf(AUTHORIZATION_BEARER + " ");
|
if (index == -1) { // 未找到
|
return null;
|
}
|
return authorization.substring(index + 7).trim();
|
}
|
|
/**
|
* 获得当前认证信息
|
*
|
* @return 认证信息
|
*/
|
public static Authentication getAuthentication() {
|
SecurityContext context = SecurityContextHolder.getContext();
|
if (context == null) {
|
return null;
|
}
|
return context.getAuthentication();
|
}
|
|
/**
|
* 获取当前用户
|
*
|
* @return 当前用户
|
*/
|
@Nullable
|
public static LoginUser getLoginUser() {
|
Authentication authentication = getAuthentication();
|
if (authentication == null) {
|
return null;
|
}
|
return authentication.getPrincipal() instanceof LoginUser ? (LoginUser) authentication.getPrincipal() : null;
|
}
|
|
/**
|
* 获得当前用户的编号,从上下文中
|
*
|
* @return 用户编号
|
*/
|
@Nullable
|
public static Long getLoginUserId() {
|
LoginUser loginUser = getLoginUser();
|
return loginUser != null ? loginUser.getId() : null;
|
}
|
|
/**
|
* 设置当前用户
|
*
|
* @param loginUser 登录用户
|
* @param request 请求
|
*/
|
public static void setLoginUser(LoginUser loginUser, HttpServletRequest request) {
|
// 创建 Authentication,并设置到上下文
|
Authentication authentication = buildAuthentication(loginUser, request);
|
SecurityContextHolder.getContext().setAuthentication(authentication);
|
}
|
|
private static Authentication buildAuthentication(LoginUser loginUser, HttpServletRequest request) {
|
// 创建 UsernamePasswordAuthenticationToken 对象
|
UsernamePasswordAuthenticationToken authenticationToken = new UsernamePasswordAuthenticationToken(
|
loginUser, null, Collections.emptyList());
|
authenticationToken.setDetails(new WebAuthenticationDetailsSource().buildDetails(request));
|
return authenticationToken;
|
}
|
|
}
|