在RCP客户端中,我们经常会使用分布式技术来访问服务器,但是由于RCP特殊的类装载机制,RMI在RCP中常常绘出问题。
由于RMI本身的要求,代码中需要设置安全管理器,以下是一个容许所有权限的安全管理器,
public class MyRMISecurityManager extends SecurityManager {
public RMISecurityManager() { }
public void checkPermission() { }
@Override
public void checkPermission(Permission arg0) { }
@Override
public void checkPermission(Permission perm, Object context) { }
}
另外,非常关键的是,在RCP客户端中需要设置类装载器,
以下是示例代码:
SecurityManager secMan = System.getSecurityManager();
ClassLoader cl = Thread.currentThread().getContextClassLoader();
try {
System.setSecurityManager(new MyRMISecurityManager());
ClassLoader parent = this.getClass().getClassLoader();
Thread.currentThread().setContextClassLoader(parent);
} finally {
System.setSecurityManager(secMan);
Thread.currentThread().setContextClassLoader(cl);
}
在RCP中访问JNDI中绑定的分布式对象,例如EJB,都需要作同样处理
由于RMI本身的要求,代码中需要设置安全管理器,以下是一个容许所有权限的安全管理器,
public class MyRMISecurityManager extends SecurityManager {
public RMISecurityManager() { }
public void checkPermission() { }
@Override
public void checkPermission(Permission arg0) { }
@Override
public void checkPermission(Permission perm, Object context) { }
}
另外,非常关键的是,在RCP客户端中需要设置类装载器,
以下是示例代码:
SecurityManager secMan = System.getSecurityManager();
ClassLoader cl = Thread.currentThread().getContextClassLoader();
try {
System.setSecurityManager(new MyRMISecurityManager());
ClassLoader parent = this.getClass().getClassLoader();
Thread.currentThread().setContextClassLoader(parent);
} finally {
System.setSecurityManager(secMan);
Thread.currentThread().setContextClassLoader(cl);
}
在RCP中访问JNDI中绑定的分布式对象,例如EJB,都需要作同样处理