public abstract class Invoker
extends java.lang.Object
invoke(java.lang.reflect.Method, java.lang.Object...)
for a web service invocation. Finally, Invoker does the actual
invocation of web service on endpoint instance.
Container also injects the provided WebServiceContext
and takes
care of invoking jakarta.annotation.PostConstruct
methods,
if present, on the endpoint implementation.Provider.createEndpoint(String, Class, Invoker, WebServiceFeature...)
Constructor and Description |
---|
Invoker() |
Modifier and Type | Method and Description |
---|---|
abstract void |
inject(WebServiceContext webServiceContext)
Jakarta XML Web Services runtimes calls this method to ask container to inject
WebServiceContext on the endpoint instance.
|
abstract java.lang.Object |
invoke(java.lang.reflect.Method m,
java.lang.Object... args)
Jakarta XML Web Services runtime calls this method to do the actual web service
invocation on endpoint instance.
|
public abstract void inject(WebServiceContext webServiceContext) throws java.lang.IllegalAccessException, java.lang.IllegalArgumentException, java.lang.reflect.InvocationTargetException
WebServiceContext
object uses thread-local information
to return the correct information during the actual endpoint invocation
regardless of how many threads are concurrently being used to serve
requests.webServiceContext
- a holder for MessageContextjava.lang.IllegalAccessException
- if the injection done
by reflection API throws this exceptionjava.lang.IllegalArgumentException
- if the injection done
by reflection API throws this exceptionjava.lang.reflect.InvocationTargetException
- if the injection done
by reflection API throws this exceptionpublic abstract java.lang.Object invoke(java.lang.reflect.Method m, java.lang.Object... args) throws java.lang.IllegalAccessException, java.lang.IllegalArgumentException, java.lang.reflect.InvocationTargetException
WebServiceContext.getMessageContext()
gives the correct
information for this invocation.m
- Method to be invoked on the serviceargs
- Method argumentsjava.lang.IllegalAccessException
- if the invocation done
by reflection API throws this exceptionjava.lang.IllegalArgumentException
- if the invocation done
by reflection API throws this exceptionjava.lang.reflect.InvocationTargetException
- if the invocation done
by reflection API throws this exceptionMethod.invoke(java.lang.Object, java.lang.Object...)