| /** | 
|  * Copyright (c) 2015-2017, Chill Zhuang 庄骞 (smallchill@163.com). | 
|  * <p> | 
|  * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  * you may not use this file except in compliance with the License. | 
|  * You may obtain a copy of the License at | 
|  * <p> | 
|  * http://www.apache.org/licenses/LICENSE-2.0 | 
|  * <p> | 
|  * Unless required by applicable law or agreed to in writing, software | 
|  * distributed under the License is distributed on an "AS IS" BASIS, | 
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  * See the License for the specific language governing permissions and | 
|  * limitations under the License. | 
|  */ | 
| package com.supersavedriving.user.core.aop; | 
|   | 
| import com.supersavedriving.user.core.common.annotion.Permission; | 
| import com.supersavedriving.user.core.shiro.check.PermissionCheckManager; | 
| import org.aspectj.lang.ProceedingJoinPoint; | 
| import org.aspectj.lang.annotation.Around; | 
| import org.aspectj.lang.annotation.Aspect; | 
| import org.aspectj.lang.annotation.Pointcut; | 
| import org.aspectj.lang.reflect.MethodSignature; | 
| import org.springframework.core.annotation.Order; | 
| import org.springframework.stereotype.Component; | 
|   | 
| import javax.naming.NoPermissionException; | 
| import java.lang.reflect.Method; | 
|   | 
| /** | 
|  * AOP 权限自定义检查 | 
|  */ | 
| @Aspect | 
| @Component | 
| @Order(200) | 
| public class PermissionAop { | 
|   | 
|     @Pointcut(value = "@annotation(com.supersavedriving.user.core.common.annotion.Permission)") | 
|     private void cutPermission() { | 
|   | 
|     } | 
|   | 
|     @Around("cutPermission()") | 
|     public Object doPermission(ProceedingJoinPoint point) throws Throwable { | 
|         MethodSignature ms = (MethodSignature) point.getSignature(); | 
|         Method method = ms.getMethod(); | 
|         Permission permission = method.getAnnotation(Permission.class); | 
|         Object[] permissions = permission.value(); | 
|         if (permissions == null || permissions.length == 0) { | 
|             //检查全体角色 | 
|             boolean result = PermissionCheckManager.checkAll(); | 
|             if (result) { | 
|                 return point.proceed(); | 
|             } else { | 
|                 throw new NoPermissionException(); | 
|             } | 
|         } else { | 
|             //检查指定角色 | 
|             boolean result = PermissionCheckManager.check(permissions); | 
|             if (result) { | 
|                 return point.proceed(); | 
|             } else { | 
|                 throw new NoPermissionException(); | 
|             } | 
|         } | 
|   | 
|     } | 
|   | 
| } |