All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.buession.web.servlet.aop.advice.aspectj.ServletHttpAnnotationAspect Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.
 * See the NOTICE file distributed with this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you 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
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * 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.
 *
 * =========================================================================================================
 *
 * This software consists of voluntary contributions made by many individuals on behalf of the
 * Apache Software Foundation. For more information on the Apache Software Foundation, please see
 * .
 *
 * +-------------------------------------------------------------------------------------------------------+
 * | License: http://www.apache.org/licenses/LICENSE-2.0.txt 										       |
 * | Author: Yong.Teng  													       |
 * | Copyright @ 2013-2019 Buession.com Inc.														       |
 * +-------------------------------------------------------------------------------------------------------+
 */
package com.buession.web.servlet.aop.advice.aspectj;

import com.buession.web.aop.aspect.WebAnnotationAspect;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author Yong.Teng
 */
@Aspect
public class ServletHttpAnnotationAspect implements WebAnnotationAspect {

    private ServletHttpAspectjAnnotationsMethodAdvice advice = new ServletHttpAspectjAnnotationsMethodAdvice();

    private final static Logger logger = LoggerFactory.getLogger(ServletHttpAnnotationAspect.class);

    @Pointcut(EXPRESSIONS)
    public void anyAnnotatedMethod(){
        logger.debug("Call ServletHttpAnnotationAspect::anyAnnotatedMethod()");
    }

    @Pointcut(EXPRESSIONS)
    void anyAnnotatedMethodCall(JoinPoint joinPoint){
        logger.debug("Call ServletHttpAnnotationAspect::anyAnnotatedMethodCall()");
    }

    @After("anyAnnotatedMethodCall(joinPoint)")
    public void executeAnnotatedMethod(JoinPoint joinPoint) throws Throwable{
        logger.debug("Call ServletHttpAnnotationAspect::executeAnnotatedMethod()");
        advice.performAfterInterception(joinPoint);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy