| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.remoting.support.RemotingSupport
org.springframework.remoting.support.RemoteAccessor
org.springframework.remoting.support.UrlBasedRemoteAccessor
org.springframework.remoting.support.RemoteInvocationBasedAccessor
org.springframework.remoting.httpinvoker.HttpInvokerClientInterceptor
public class HttpInvokerClientInterceptor
MethodInterceptor for accessing an
 HTTP invoker service. The service URL must be an HTTP URL exposing
 an HTTP invoker service.
 
Serializes remote invocation objects and deserializes remote invocation result objects. Uses Java serialization just like RMI, but provides the same ease of setup as Caucho's HTTP-based Hessian and Burlap protocols.
HTTP invoker is a very extensible and customizable protocol.
 It supports the RemoteInvocationFactory mechanism, like RMI invoker,
 allowing to include additional invocation attributes (for example,
 a security context). Furthermore, it allows to customize request
 execution via the HttpInvokerRequestExecutor strategy.
 
Can use the JDK's RMIClassLoader to load
 classes from a given codebase, performing
 on-demand dynamic code download from a remote location. The codebase
 can consist of multiple URLs, separated by spaces. Note that
 RMIClassLoader requires a SecurityManager to be set, analogous to
 when using dynamic class download with standard RMI!
 (See the RMI documentation for details.)
UrlBasedRemoteAccessor.setServiceUrl(java.lang.String), 
setCodebaseUrl(java.lang.String), 
RemoteInvocationBasedAccessor.setRemoteInvocationFactory(org.springframework.remoting.support.RemoteInvocationFactory), 
setHttpInvokerRequestExecutor(org.springframework.remoting.httpinvoker.HttpInvokerRequestExecutor), 
HttpInvokerServiceExporter, 
HttpInvokerProxyFactoryBean, 
RMIClassLoader| Field Summary | 
|---|
| Fields inherited from class org.springframework.remoting.support.RemotingSupport | 
|---|
| logger | 
| Constructor Summary | |
|---|---|
| HttpInvokerClientInterceptor() | |
| Method Summary | |
|---|---|
|  void | afterPropertiesSet()Invoked by a BeanFactory after it has set all bean properties supplied (and satisfied BeanFactoryAware and ApplicationContextAware). | 
| protected  RemoteAccessException | convertHttpInvokerAccessException(Throwable ex)Convert the given HTTP invoker access exception to an appropriate Spring RemoteAccessException. | 
| protected  RemoteInvocationResult | executeRequest(RemoteInvocation invocation)Execute the given remote invocation via the HttpInvokerRequestExecutor. | 
| protected  RemoteInvocationResult | executeRequest(RemoteInvocation invocation,
               MethodInvocation originalInvocation)Execute the given remote invocation via the HttpInvokerRequestExecutor. | 
|  String | getCodebaseUrl()Return the codebase URL to download classes from if not found locally. | 
|  HttpInvokerRequestExecutor | getHttpInvokerRequestExecutor()Return the HttpInvokerRequestExecutor used by this remote accessor. | 
|  Object | invoke(MethodInvocation methodInvocation) | 
|  void | setCodebaseUrl(String codebaseUrl)Set the codebase URL to download classes from if not found locally. | 
|  void | setHttpInvokerRequestExecutor(HttpInvokerRequestExecutor httpInvokerRequestExecutor)Set the HttpInvokerRequestExecutor implementation to use for executing remote invocations. | 
| Methods inherited from class org.springframework.remoting.support.RemoteInvocationBasedAccessor | 
|---|
| createRemoteInvocation, getRemoteInvocationFactory, recreateRemoteInvocationResult, setRemoteInvocationFactory | 
| Methods inherited from class org.springframework.remoting.support.UrlBasedRemoteAccessor | 
|---|
| getServiceUrl, setServiceUrl | 
| Methods inherited from class org.springframework.remoting.support.RemoteAccessor | 
|---|
| getServiceInterface, setServiceInterface | 
| Methods inherited from class org.springframework.remoting.support.RemotingSupport | 
|---|
| getBeanClassLoader, overrideThreadContextClassLoader, resetThreadContextClassLoader, setBeanClassLoader | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Methods inherited from interface org.springframework.remoting.httpinvoker.HttpInvokerClientConfiguration | 
|---|
| getServiceUrl | 
| Constructor Detail | 
|---|
public HttpInvokerClientInterceptor()
| Method Detail | 
|---|
public void setCodebaseUrl(String codebaseUrl)
Follows RMI's codebase conventions for dynamic class download. In contrast to RMI, where the server determines the URL for class download (via the "java.rmi.server.codebase" system property), it's the client that determines the codebase URL here. The server will usually be the same as for the service URL, just pointing to a different path there.
UrlBasedRemoteAccessor.setServiceUrl(java.lang.String), 
CodebaseAwareObjectInputStream, 
RMIClassLoaderpublic String getCodebaseUrl()
getCodebaseUrl in interface HttpInvokerClientConfigurationnull if noneRMIClassLoaderpublic void setHttpInvokerRequestExecutor(HttpInvokerRequestExecutor httpInvokerRequestExecutor)
Default is SimpleHttpInvokerRequestExecutor. Alternatively,
 consider using CommonsHttpInvokerRequestExecutor for more
 sophisticated needs.
SimpleHttpInvokerRequestExecutor, 
CommonsHttpInvokerRequestExecutorpublic HttpInvokerRequestExecutor getHttpInvokerRequestExecutor()
Creates a default SimpleHttpInvokerRequestExecutor if no executor has been initialized already.
public void afterPropertiesSet()
InitializingBeanThis method allows the bean instance to perform initialization only possible when all bean properties have been set and to throw an exception in the event of misconfiguration.
afterPropertiesSet in interface InitializingBeanafterPropertiesSet in class UrlBasedRemoteAccessor
public Object invoke(MethodInvocation methodInvocation)
              throws Throwable
invoke in interface MethodInterceptorThrowable
protected RemoteInvocationResult executeRequest(RemoteInvocation invocation,
                                                MethodInvocation originalInvocation)
                                         throws Exception
This implementation delegates to executeRequest(RemoteInvocation).
 Can be overridden to react to the specific original MethodInvocation.
invocation - the RemoteInvocation to executeoriginalInvocation - the original MethodInvocation (can e.g. be cast
 to the ProxyMethodInvocation interface for accessing user attributes)
Exception - in case of errors
protected RemoteInvocationResult executeRequest(RemoteInvocation invocation)
                                         throws Exception
Can be overridden in subclasses to pass a different configuration object to the executor. Alternatively, add further configuration properties in a subclass of this accessor: By default, the accessor passed itself as configuration object to the executor.
invocation - the RemoteInvocation to execute
IOException - if thrown by I/O operations
ClassNotFoundException - if thrown during deserialization
Exception - in case of general errorsgetHttpInvokerRequestExecutor(), 
HttpInvokerClientConfigurationprotected RemoteAccessException convertHttpInvokerAccessException(Throwable ex)
ex - the exception to convert
| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||