|
|
@ -1,10 +1,11 @@
|
|
|
|
package com.luoo.user.aspect;
|
|
|
|
package com.luoo.user.aspect;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.lang.reflect.Field;
|
|
|
|
import java.lang.reflect.Field;
|
|
|
|
import java.lang.reflect.Method;
|
|
|
|
import java.lang.reflect.Method;
|
|
|
|
import java.lang.reflect.Parameter;
|
|
|
|
import java.lang.reflect.Parameter;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import javax.servlet.http.HttpServletRequest;
|
|
|
|
|
|
|
|
|
|
|
|
import org.apache.commons.lang3.ArrayUtils;
|
|
|
|
import org.apache.commons.lang3.ArrayUtils;
|
|
|
|
import org.aspectj.lang.JoinPoint;
|
|
|
|
import org.aspectj.lang.JoinPoint;
|
|
|
|
import org.aspectj.lang.annotation.Aspect;
|
|
|
|
import org.aspectj.lang.annotation.Aspect;
|
|
|
@ -12,21 +13,32 @@ import org.aspectj.lang.annotation.Before;
|
|
|
|
import org.aspectj.lang.reflect.MethodSignature;
|
|
|
|
import org.aspectj.lang.reflect.MethodSignature;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
import org.springframework.web.context.request.RequestContextHolder;
|
|
|
|
|
|
|
|
import org.springframework.web.context.request.ServletRequestAttributes;
|
|
|
|
|
|
|
|
|
|
|
|
import com.luoo.user.annotation.GlobalInterceptor;
|
|
|
|
import com.luoo.user.annotation.GlobalInterceptor;
|
|
|
|
import com.luoo.user.annotation.VerifyParam;
|
|
|
|
import com.luoo.user.annotation.VerifyParam;
|
|
|
|
|
|
|
|
import com.luoo.user.constants.Constants;
|
|
|
|
import com.luoo.user.util.VerifyUtils;
|
|
|
|
import com.luoo.user.util.VerifyUtils;
|
|
|
|
|
|
|
|
|
|
|
|
import api.StatusCode;
|
|
|
|
import api.StatusCode;
|
|
|
|
|
|
|
|
import dto.UserLoginDto;
|
|
|
|
import exception.BizException;
|
|
|
|
import exception.BizException;
|
|
|
|
|
|
|
|
import util.JwtUtil;
|
|
|
|
import util.StringTools;
|
|
|
|
import util.StringTools;
|
|
|
|
|
|
|
|
|
|
|
|
@Aspect
|
|
|
|
@Aspect
|
|
|
|
@Component("operationAspect")
|
|
|
|
@Component("operationAspect")
|
|
|
|
public class OperationAspect {
|
|
|
|
public class OperationAspect {
|
|
|
|
static Logger logger = LoggerFactory.getLogger(OperationAspect.class);
|
|
|
|
static Logger logger = LoggerFactory.getLogger(OperationAspect.class);
|
|
|
|
private static final String[] BASE_TYPE_ARRAY=new String[] {"java.lang.String","java.lang.Integer","java.lang.Long"};
|
|
|
|
private static final String[] BASE_TYPE_ARRAY = new String[] { "java.lang.String", "java.lang.Integer",
|
|
|
|
|
|
|
|
"java.lang.Long" };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
|
|
private JwtUtil jwtUtil;
|
|
|
|
|
|
|
|
|
|
|
|
@Before("@annotation(com.luoo.user.annotation.GlobalInterceptor)")
|
|
|
|
@Before("@annotation(com.luoo.user.annotation.GlobalInterceptor)")
|
|
|
|
public void interceptorDo(JoinPoint point) {
|
|
|
|
public void interceptorDo(JoinPoint point) {
|
|
|
|
Object[] arguments = point.getArgs();
|
|
|
|
Object[] arguments = point.getArgs();
|
|
|
@ -35,10 +47,52 @@ public class OperationAspect {
|
|
|
|
if (null == interceptor) {
|
|
|
|
if (null == interceptor) {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* 登录校验
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (interceptor.checkLogin()) {
|
|
|
|
|
|
|
|
checkLogin();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* 管理用户登录校验
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (interceptor.checkAdminLogin()) {
|
|
|
|
|
|
|
|
checkAdminLogin();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* 校验参数
|
|
|
|
|
|
|
|
*/
|
|
|
|
if (interceptor.checkParam()) {
|
|
|
|
if (interceptor.checkParam()) {
|
|
|
|
validateParams(method, arguments);
|
|
|
|
validateParams(method, arguments);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void checkAdminLogin() {
|
|
|
|
|
|
|
|
UserLoginDto userLoginDto = getUserLoginDtoFromToken();
|
|
|
|
|
|
|
|
if (userLoginDto == null) {
|
|
|
|
|
|
|
|
throw new BizException(StatusCode.UNAUTHORIZED);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Constants.TOKEN_ROLE_ADMIN_USER.equals(userLoginDto.getRoles())) {
|
|
|
|
|
|
|
|
throw new BizException(StatusCode.FORBIDDEN);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void checkLogin() {
|
|
|
|
|
|
|
|
UserLoginDto userLoginDto = getUserLoginDtoFromToken();
|
|
|
|
|
|
|
|
if (userLoginDto == null) {
|
|
|
|
|
|
|
|
throw new BizException(StatusCode.UNAUTHORIZED);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private UserLoginDto getUserLoginDtoFromToken() {
|
|
|
|
|
|
|
|
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes())
|
|
|
|
|
|
|
|
.getRequest();
|
|
|
|
|
|
|
|
String token = request.getHeader("token");
|
|
|
|
|
|
|
|
return jwtUtil.getUserLoginDto(token);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void validateParams(Method method, Object[] arguments) {
|
|
|
|
private void validateParams(Method method, Object[] arguments) {
|
|
|
|
Parameter[] parameters = method.getParameters();
|
|
|
|
Parameter[] parameters = method.getParameters();
|
|
|
|
for (int i = 0; i < parameters.length; i++) {
|
|
|
|
for (int i = 0; i < parameters.length; i++) {
|
|
|
@ -56,6 +110,7 @@ public class OperationAspect {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void checkObjValue(Parameter parameter, Object value) {
|
|
|
|
private void checkObjValue(Parameter parameter, Object value) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
String typeName = parameter.getParameterizedType().getTypeName();
|
|
|
|
String typeName = parameter.getParameterizedType().getTypeName();
|
|
|
@ -83,10 +138,12 @@ public class OperationAspect {
|
|
|
|
if (isEmpty && verifyParam.required()) {
|
|
|
|
if (isEmpty && verifyParam.required()) {
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!isEmpty&&(-1!=verifyParam.max()&&verifyParam.max()<length||-1!=verifyParam.min()&&verifyParam.min()>length)) {
|
|
|
|
if (!isEmpty && (-1 != verifyParam.max() && verifyParam.max() < length
|
|
|
|
|
|
|
|
|| -1 != verifyParam.min() && verifyParam.min() > length)) {
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!isEmpty&&!StringTools.isEmpty(verifyParam.regex().getRegex())&&!VerifyUtils.verify(verifyParam.regex(), String.valueOf(value))) {
|
|
|
|
if (!isEmpty && !StringTools.isEmpty(verifyParam.regex().getRegex())
|
|
|
|
|
|
|
|
&& !VerifyUtils.verify(verifyParam.regex(), String.valueOf(value))) {
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
throw new BizException(StatusCode.VALIDATE_FAILED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|