MBeanServerInvocationHandler (Java 2 Platform SE 5.0) (original) (raw)
javax.management
Class MBeanServerInvocationHandler
java.lang.Object
javax.management.MBeanServerInvocationHandler
All Implemented Interfaces:
public class MBeanServerInvocationHandler
extends Object
implements InvocationHandler
InvocationHandler that forwards methods in an MBean's management interface through the MBean server to the MBean.
Given an MBeanServerConnection, the ObjectName of an MBean within that MBean server, and a Java interfaceIntf
that describes the management interface of the MBean using the patterns for a Standard MBean, this class can be used to construct a proxy for the MBean. The proxy implements the interface Intf
such that all of its methods are forwarded through the MBean server to the MBean.
If you have an MBean server mbs
containing an MBean with ObjectName name
, and if the MBean's management interface is described by the Java interfaceIntf
, you can construct a proxy for the MBean like this:
Intf proxy = (Intf) MBeanServerInvocationHandler.[newProxyInstance](../../javax/management/MBeanServerInvocationHandler.html#newProxyInstance%28javax.management.MBeanServerConnection, javax.management.ObjectName, java.lang.Class, boolean%29)(mbs, name, Intf.class, false);
Suppose, for example, Intf
looks like this:
public interface Intf { public String getSomeAttribute(); public void setSomeAttribute(String value); public void someOperation(String param1, int param2); }
Then you can execute:
proxy.getSomeAttribute()
which will result in a call tombs.
[getAttribute](../../javax/management/MBeanServerConnection.html#getAttribute%28javax.management.ObjectName, java.lang.String%29)(name, "SomeAttribute")
.proxy.setSomeAttribute("whatever")
which will result in a call tombs.
[setAttribute](../../javax/management/MBeanServerConnection.html#setAttribute%28javax.management.ObjectName, javax.management.Attribute%29)(name, new Attribute("SomeAttribute", "whatever"))
.proxy.someOperation("param1", 2)
which will be translated into a call tombs.
[invoke](../../javax/management/MBeanServerConnection.html#invoke%28javax.management.ObjectName, java.lang.String, java.lang.Object[], java.lang.String[]%29)(name, "someOperation", <etc>)
.
If the last parameter to [newProxyInstance](../../javax/management/MBeanServerInvocationHandler.html#newProxyInstance%28javax.management.MBeanServerConnection, javax.management.ObjectName, java.lang.Class, boolean%29) is true
, then the MBean is assumed to be a NotificationBroadcaster or NotificationEmitter and the returned proxy will implement NotificationEmitter. A call to [NotificationBroadcaster.addNotificationListener(javax.management.NotificationListener, javax.management.NotificationFilter, java.lang.Object)](../../javax/management/NotificationBroadcaster.html#addNotificationListener%28javax.management.NotificationListener, javax.management.NotificationFilter, java.lang.Object%29) on the proxy will result in a call to [MBeanServerConnection.addNotificationListener(ObjectName, NotificationListener, NotificationFilter, Object)](../../javax/management/MBeanServerConnection.html#addNotificationListener%28javax.management.ObjectName, javax.management.NotificationListener, javax.management.NotificationFilter, java.lang.Object%29), and likewise for the other methods of NotificationBroadcaster and NotificationEmitter.
The methods Object.toString(), Object.hashCode(), and Object.equals(Object), when invoked on a proxy using this invocation handler, are forwarded to the MBean server as methods on the proxied MBean. This will only work if the MBean declares those methods in its management interface.
Since:
1.5
Constructor Summary |
---|
[MBeanServerInvocationHandler](../../javax/management/MBeanServerInvocationHandler.html#MBeanServerInvocationHandler%28javax.management.MBeanServerConnection, javax.management.ObjectName%29)(MBeanServerConnection connection,ObjectName objectName) Invocation handler that forwards methods through an MBean server. |
Method Summary | |
---|---|
Object | [invoke](../../javax/management/MBeanServerInvocationHandler.html#invoke%28java.lang.Object, java.lang.reflect.Method, java.lang.Object[]%29)(Object proxy,Method method,Object[] args) Processes a method invocation on a proxy instance and returns the result. |
static Object | [newProxyInstance](../../javax/management/MBeanServerInvocationHandler.html#newProxyInstance%28javax.management.MBeanServerConnection, javax.management.ObjectName, java.lang.Class, boolean%29)(MBeanServerConnection connection,ObjectName objectName,Class interfaceClass, boolean notificationBroadcaster) Return a proxy that implements the given interface by forwarding its methods through the given MBean server to the named MBean. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, [wait](../../java/lang/Object.html#wait%28long, int%29) |
Constructor Detail |
---|
MBeanServerInvocationHandler
public MBeanServerInvocationHandler(MBeanServerConnection connection, ObjectName objectName)
Invocation handler that forwards methods through an MBean server. This constructor may be called instead of relying on[newProxyInstance(javax.management.MBeanServerConnection, javax.management.ObjectName, java.lang.Class, boolean)](../../javax/management/MBeanServerInvocationHandler.html#newProxyInstance%28javax.management.MBeanServerConnection, javax.management.ObjectName, java.lang.Class, boolean%29), for instance if you need to supply a different ClassLoader to [Proxy.newProxyInstance](../../java/lang/reflect/Proxy.html#newProxyInstance%28java.lang.ClassLoader, java.lang.Class[], java.lang.reflect.InvocationHandler%29).
Parameters:
connection
- the MBean server connection through which all methods of a proxy using this handler will be forwarded.
objectName
- the name of the MBean within the MBean server to which methods will be forwarded.
Method Detail |
---|
newProxyInstance
public static Object newProxyInstance(MBeanServerConnection connection, ObjectName objectName, Class interfaceClass, boolean notificationBroadcaster)
Return a proxy that implements the given interface by forwarding its methods through the given MBean server to the named MBean.
This method is equivalent to [Proxy.newProxyInstance](../../java/lang/reflect/Proxy.html#newProxyInstance%28java.lang.ClassLoader, java.lang.Class[], java.lang.reflect.InvocationHandler%29)(interfaceClass.getClassLoader(), interfaces, handler)
. Here handler
is the result of [new MBeanServerInvocationHandler(connection, objectName)](../../javax/management/MBeanServerInvocationHandler.html#MBeanServerInvocationHandler%28javax.management.MBeanServerConnection, javax.management.ObjectName%29), andinterfaces
is an array that has one element ifnotificationBroadcaster
is false and two if it is true. The first element of interfaces
isinterfaceClass
and the second, if present, isNotificationEmitter.class
.
Parameters:
connection
- the MBean server to forward to.
objectName
- the name of the MBean withinconnection
to forward to.
interfaceClass
- the management interface that the MBean exports, which will also be implemented by the returned proxy.
notificationBroadcaster
- make the returned proxy implement NotificationEmitter by forwarding its methods via connection
.
Returns:
the new proxy instance.
invoke
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable
Description copied from interface: [InvocationHandler](../../java/lang/reflect/InvocationHandler.html#invoke%28java.lang.Object, java.lang.reflect.Method, java.lang.Object[]%29)
Processes a method invocation on a proxy instance and returns the result. This method will be invoked on an invocation handler when a method is invoked on a proxy instance that it is associated with.
Specified by:
[invoke](../../java/lang/reflect/InvocationHandler.html#invoke%28java.lang.Object, java.lang.reflect.Method, java.lang.Object[]%29)
in interface [InvocationHandler](../../java/lang/reflect/InvocationHandler.html "interface in java.lang.reflect")
Parameters:
proxy
- the proxy instance that the method was invoked on
method
- the Method
instance corresponding to the interface method invoked on the proxy instance. The declaring class of the Method
object will be the interface that the method was declared in, which may be a superinterface of the proxy interface that the proxy class inherits the method through.
args
- an array of objects containing the values of the arguments passed in the method invocation on the proxy instance, or null
if interface method takes no arguments. Arguments of primitive types are wrapped in instances of the appropriate primitive wrapper class, such asjava.lang.Integer
or java.lang.Boolean
.
Returns:
the value to return from the method invocation on the proxy instance. If the declared return type of the interface method is a primitive type, then the value returned by this method must be an instance of the corresponding primitive wrapper class; otherwise, it must be a type assignable to the declared return type. If the value returned by this method isnull
and the interface method's return type is primitive, then a NullPointerException
will be thrown by the method invocation on the proxy instance. If the value returned by this method is otherwise not compatible with the interface method's declared return type as described above, a ClassCastException
will be thrown by the method invocation on the proxy instance.
Throws:
[Throwable](../../java/lang/Throwable.html "class in java.lang")
- the exception to throw from the method invocation on the proxy instance. The exception's type must be assignable either to any of the exception types declared in thethrows
clause of the interface method or to the unchecked exception types java.lang.RuntimeException
or java.lang.Error
. If a checked exception is thrown by this method that is not assignable to any of the exception types declared in the throws
clause of the interface method, then anUndeclaredThrowableException containing the exception that was thrown by this method will be thrown by the method invocation on the proxy instance.
See Also:
Submit a bug or feature
For further API reference and developer documentation, see Java 2 SDK SE Developer Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 2004, 2010 Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.