注解的用法

1.用于切面编程

@Target({ElementType.PARAMETER, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public  @interface SystemServiceLog {

    String description()  default "";


}
@Pointcut("@annotation(com.gidoor.zcwd.web.annotation.SystemServiceLog)")
public  void serviceAspect() {
}
@AfterThrowing(pointcut = "serviceAspect()", throwing = "e")
public  void doAfterThrowing(JoinPoint joinPoint, Throwable e) {
    HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
}
2.用于拦截

/**
 * 权限限制
 * @author  2015-12-12 18:29:02
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface PermessionLimit {
   
   /**
    * 登录拦截 (默认拦截)
    */
   boolean limit() default true;

}

/**
 * 权限拦截, 简易版
 * @author  2015-12-12 18:09:04
 */
public class PermissionInterceptor extends HandlerInterceptorAdapter {
   
   
   @Override
   public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
      
      if (!(handler instanceof HandlerMethod)) {
         return super.preHandle(request, response, handler);
      }
      
      if (!ifLogin(request)) {
         HandlerMethod method = (HandlerMethod)handler;
         PermessionLimit permission = method.getMethodAnnotation(PermessionLimit.class);
         if (permission == null || permission.limit()) {
            response.sendRedirect(request.getContextPath() + "/toLogin");
            //request.getRequestDispatcher("/toLogin").forward(request, response);
            return false;
         }
      }
      
      return super.preHandle(request, response, handler);
   }
   
}

@RequestMapping("/toLogin")
@PermessionLimit(limit=false)
public String toLogin(Model model, HttpServletRequest request) {
   if (PermissionInterceptor.ifLogin(request)) {
      return "redirect:/";
   }
   return "login";




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值