當前位置: 首頁>>代碼示例>>Java>>正文


Java InvocationContext.proceed方法代碼示例

本文整理匯總了Java中javax.interceptor.InvocationContext.proceed方法的典型用法代碼示例。如果您正苦於以下問題:Java InvocationContext.proceed方法的具體用法?Java InvocationContext.proceed怎麽用?Java InvocationContext.proceed使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.interceptor.InvocationContext的用法示例。


在下文中一共展示了InvocationContext.proceed方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: interceptMethodInvocation

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object interceptMethodInvocation(InvocationContext invocationContext) throws Exception {

    final String methodName = invocationContext.getMethod().getName();
    final String className = invocationContext.getTarget().getClass().getName();

    Logger logger = Logger.getLogger(className);

    final long timeBeforeMethodInvocation;
    final long timeAfterMethodInvocation;
    final long millis;
    logger.entering(className, methodName);
    timeBeforeMethodInvocation = System.currentTimeMillis();

    try {
        return invocationContext.proceed();
    } finally {
        timeAfterMethodInvocation = System.currentTimeMillis();
        millis = timeAfterMethodInvocation - timeBeforeMethodInvocation;
        logger.fine("Method took -> " + millis + " millis to be executed!");
        logger.exiting(className, methodName);
    }
}
 
開發者ID:harperkej,項目名稱:store-app-ee,代碼行數:24,代碼來源:LoggingInterceptor.java

示例2: accessAllowed

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object accessAllowed(InvocationContext ctx) throws Exception {
	Method businessAction = ctx.getMethod();
	Object managedBean = ctx.getTarget();
	boolean isAccessAllowed = false;

	try {

		ActionContext securityContext = new ActionContext(getUser(userModule));
		securityContext.setBusinessAction(businessAction);
		securityContext.setManagedBean(managedBean);

		isAccessAllowed = forumsACLProvider.hasAccess(securityContext);
		if (!isAccessAllowed)
			return null;
	} catch (NoSuchMethodException nsme) {
		throw new FacesException("Error calling action method of component with id " + nsme, nsme);
	} catch (Exception e) {
		throw new FacesException("Error calling action method of component with id " + e, e);
	}
	return ctx.proceed();
}
 
開發者ID:PacktPublishing,項目名稱:Mastering-Java-EE-Development-with-WildFly,代碼行數:23,代碼來源:AuthorizationListener.java

示例3: ensureIsNotServiceProvider

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
/**
 * Checks if OSCM acts as a SAML service provider. If so, an
 * UnsupportedOperationException will be thrown.
 */
@AroundInvoke
public Object ensureIsNotServiceProvider(InvocationContext context)
        throws Exception {
    Object result = null;

    if (configService.isServiceProvider()) {
        UnsupportedOperationException e = new UnsupportedOperationException(
                "It is forbidden to perform this operation if a OSCM acts as a SAML service provider.");

        Log4jLogger logger = LoggerFactory.getLogger(context.getTarget()
                .getClass());
        logger.logError(Log4jLogger.SYSTEM_LOG, e,
                LogMessageIdentifier.ERROR_OPERATION_FORBIDDEN_FOR_SAML_SP);
        throw e;
    }

    result = context.proceed();

    return result;
}
 
開發者ID:servicecatalog,項目名稱:oscm,代碼行數:25,代碼來源:ServiceProviderInterceptor.java

示例4: aroundInvoke

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object aroundInvoke(final InvocationContext invocationContext) throws Exception {
    KeycloakToken keycloakToken = null;

    Map<String, Object> contextData = invocationContext.getContextData();
    if (contextData.containsKey(KeycloakToken.TOKEN_KEY)) {
        keycloakToken = (KeycloakToken) contextData.get(KeycloakToken.TOKEN_KEY);
        logger.info("Successfully found KeycloakToken passed from client");

        ContextStateCache stateCache = null;
        try {
            try {
                // We have been requested to use an authentication token so now we attempt the switch.
                // This userPrincipal and credential will be found by JAAS login modules
                SimplePrincipal userPrincipal = new SimplePrincipal(keycloakToken.getUsername());
                String accessToken = keycloakToken.getToken();
                stateCache = SecurityActions.pushIdentity(userPrincipal, accessToken);
                logger.infof("Successfully pushed userPrincipal %s and his credential", userPrincipal.getName());

            } catch (Exception e) {
                logger.error("Failed to switch security context for user", e);
                // Don't propagate the exception stacktrace back to the client for security reasons
                throw new EJBAccessException("Unable to attempt switching of user.");
            }

            return invocationContext.proceed();
        } finally {
            // switch back to original context
            if (stateCache != null) {
                SecurityActions.popIdentity(stateCache);
                ;
            }
        }

    } else {
        logger.warn("No Keycloak token found");
        return invocationContext.proceed();
    }
}
 
開發者ID:mposolda,項目名稱:keycloak-remote-ejb,代碼行數:40,代碼來源:ServerSecurityInterceptor.java

示例5: aroundInvoke

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object aroundInvoke(InvocationContext context) {
    // close circuit after recovery time

    // if circuit is open
    //   return null;

    try {
        return context.proceed();
    } catch (Exception e) {

        // record exception
        // increase failure counter
        // open circuit if failure exceeds threshold

        return null;
    }
}
 
開發者ID:PacktPublishing,項目名稱:Architecting-Modern-Java-EE-Applications,代碼行數:19,代碼來源:CircuitBreaker.java

示例6: wrap

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object wrap(InvocationContext ctx) throws Exception {
    // first, let's find where this is annotated:
    Method method = ctx.getMethod();
    Class<?> resourceClass = method.getDeclaringClass();

    boolean trace = true;
    if (resourceClass.isAnnotationPresent(Traced.class)) {
        trace = resourceClass.getAnnotation(Traced.class).value();
    }

    if (method.isAnnotationPresent(Traced.class)) {
        trace = method.getAnnotation(Traced.class).value();
    }

    if (trace) {
        return super.wrap(ctx);
    } else {
        return ctx.proceed();
    }
}
 
開發者ID:opentracing-contrib,項目名稱:java-cdi,代碼行數:22,代碼來源:CdiOpenTracingInterceptor.java

示例7: filter

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
/**
 * If there is a {@link Throwable} thrown in the underlying method call, the exception is converted into an empty
 * Optional, unless the {@link Error} or {@link Exception} is listed as ignorable in {@link Semisafe} annotation.
 *
 * @param invocationContext Interceptor's invocation context
 * @return Value returned by the underlying method call. Empty optional in case of an exception.
 */
@AroundInvoke
public Object filter(InvocationContext invocationContext) throws Throwable {
    try {
        final Object returnedObject = invocationContext.proceed();

        if (returnedObject == null || !(returnedObject instanceof Optional)) {
            return Optional.empty();
        }
        return returnedObject;
    } catch (Throwable throwable) {
        if (isIgnoredThrowable(throwable, invocationContext.getMethod())) {
            throw throwable;
        }
        super.throwExecutionErrorEvent(invocationContext, throwable);
        return Optional.empty();
    }
}
 
開發者ID:Pscheidl,項目名稱:FortEE,代碼行數:25,代碼來源:SemisafeInterceptor.java

示例8: aroundInvoke

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object aroundInvoke(InvocationContext ic) throws Exception {

	Object returnObject = null;
	try {
		// avant
		((ConnectionSupport) ic.getTarget()).setConnection(connectionProvider.openConnection());
		returnObject = ic.proceed();
	} catch (SQLException e) {
		throw new RuntimeException(e);
	} finally {
		// apres
		connectionProvider.closeJDBC(((ConnectionSupport) ic.getTarget()).getConnection(), null, null);
	}

	return returnObject;
}
 
開發者ID:imie-source,項目名稱:CDPN-N-10-SHARE,代碼行數:18,代碼來源:ConnectionManager.java

示例9: logAroundInvoke

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object logAroundInvoke(InvocationContext ic) throws Exception {
  Class clazz = ic.getMethod().getDeclaringClass();
  Log log = ic.getMethod().getAnnotation(Log.class);
  if (DataHelper.hasBlank(log)) {
    log = (Log) clazz.getAnnotation(Log.class);
  }

  boolean secure = (!DataHelper.hasBlank(log) && log.secure());
  Object[] params = new Object[]{clazz.getName(), ic.getMethod().getName(),
    Joiner.on(", ").useForNull("").join(ic.getParameters())};
  L.debug("Entering - {}#{} : " + (secure ? "*****" : "{}"), ic.getMethod().getDeclaringClass().getSimpleName(),
      ic.getMethod().getName(), params);

  Object result = ic.proceed();
  params[2] = result;
  L.debug("Exiting - {}#{} : " + (secure ? "*****" : "{}"), ic.getMethod().getDeclaringClass().getSimpleName(),
      ic.getMethod().getName(), result);

  return result;
}
 
開發者ID:hextremelabs,項目名稱:lib-ussd,代碼行數:22,代碼來源:Internal.java

示例10: controlInvoke

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object controlInvoke(InvocationContext ctx) throws Exception {
   log.debug("execute CibetContextInterceptor with " + ctx);
   boolean isNewlyManaged = false;
   AuthenticationProvider auth = new InvocationContextAuthenticationProvider(ctx.getContextData());
   AuthenticationProvider anonymousAuth = new AnonymousAuthenticationProvider();
   try {
      isNewlyManaged = Context.start(null, auth, anonymousAuth);
      return ctx.proceed();
   } finally {
      if (isNewlyManaged) {
         Context.end();
      } else {
         Context.internalRequestScope().getAuthenticationProvider().getProviderChain().remove(auth);
         Context.internalRequestScope().getAuthenticationProvider().getProviderChain().remove(anonymousAuth);
      }
   }
}
 
開發者ID:Wolfgang-Winter,項目名稱:cibet,代碼行數:19,代碼來源:CibetContextInterceptor.java

示例11: logMyCall

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
	public Object logMyCall(InvocationContext context) throws Exception {
		
		// you can get the called method 
		Method method = context.getMethod();
		
		// and the class of that method, of course
		Class<?> clazz = method.getDeclaringClass();
		
		// you can get the parameters
		Object[] params = context.getParameters();
		//you can set (!) the parameters....
//		context.setParameters(...);
		
		// you can get the target class (the instance of clazz on which the method was called)
//		context.getTarget();

		
		// do what you need 
		System.out.println("called " + method.getName() + " on class " + clazz+ " params="+listParams(params));
		
		// invoke the method or let the next interceptor do its work
		return context.proceed();
	}
 
開發者ID:notsojug,項目名稱:jug-material,代碼行數:25,代碼來源:LoggedInterceptor.java

示例12: logMethodCall

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object logMethodCall(InvocationContext invocationContext) throws Exception {
    Object interceptedObject = invocationContext.getTarget();
    Method interceptedMethod = invocationContext.getMethod();

    System.out.println("Entering "
            + interceptedObject.getClass().getName() + "."
            + interceptedMethod.getName() + "()");

    Object o = invocationContext.proceed();

    System.out.println("Leaving  "
            + interceptedObject.getClass().getName() + "."
            + interceptedMethod.getName() + "()");

    return o;
}
 
開發者ID:PacktPublishing,項目名稱:Java-EE-7-Development-with-NetBeans-8,代碼行數:18,代碼來源:LoggingInterceptor.java

示例13: logMethodCall

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
@AroundInvoke
public Object logMethodCall(InvocationContext invocationContext)
        throws Exception {

    logger.log(Level.INFO, new StringBuilder("entering ").append(
            invocationContext.getMethod().getName()).append(
            " method").toString());

    Object retVal = invocationContext.proceed();

    logger.log(Level.INFO, new StringBuilder("leaving ").append(
            invocationContext.getMethod().getName()).append(
            " method").toString());

    return retVal;
}
 
開發者ID:PacktPublishing,項目名稱:Java-EE-7-Development-with-NetBeans-8,代碼行數:17,代碼來源:LoggingInterceptor.java

示例14: countedCallable

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
private <E extends Member & AnnotatedElement> Object countedCallable(InvocationContext context, E element) throws Exception {
    MetricResolver.Of<Counted> counted = resolver.counted(bean.getBeanClass(), element);
    String name = counted.metricName();
    Counter counter = (Counter) registry.getCounters().get(name);
    if (counter == null) {
        throw new IllegalStateException("No counter with name [" + name + "] found in registry [" + registry + "]");
    }
    LOGGER.debugf("Increment counter [metricName: %s]", name);
    counter.inc();
    try {
        return context.proceed();
    } finally {
        if (!counted.metricAnnotation().monotonic()) {
            LOGGER.debugf("Decrement counter [metricName: %s]", name);
            counter.dec();
        }
    }
}
 
開發者ID:wildfly-swarm,項目名稱:wildfly-swarm,代碼行數:19,代碼來源:CountedInterceptor.java

示例15: proceedAndSendMessage

import javax.interceptor.InvocationContext; //導入方法依賴的package包/類
/**
 * Proceed the method and send MessageToClient to topic
 * @param ctx
 * @param topic
 * @return
 * @throws Exception
 */
Object proceedAndSendMessage(InvocationContext ctx, String topic, boolean jsonPayload) throws Exception {
	MessageToClient messageToClient = new MessageToClient();
	messageToClient.setId(topic);
	Object result = ctx.proceed();
	if(jsonPayload) {
		if(!String.class.isInstance(result)) {
			throw new UnsupportedOperationException("Method annotated JsTopic(jsonPayload=true) must return String type and correct Json.");
		}
		messageToClient.setJson((String) result);
	} else {
		messageToClient.setResponse(result);
	}
	wsEvent.fire(messageToClient);
	return result;
}
 
開發者ID:ocelotds,項目名稱:ocelot,代碼行數:23,代碼來源:JsTopicInterceptor.java


注:本文中的javax.interceptor.InvocationContext.proceed方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。