
您可以编写一个小的加载器应用程序,以创建一个新的自定义类加载器。然后可以使用此类加载器加载您的应用程序类。
然后,在自定义类加载器中,当应用程序尝试访问要列入黑名单的类时,可以引发ClassNotFoundException。
您将需要重载load()方法。如果允许该类,则此方法将负责在您列入黑名单的类上引发异常,或者将其委托给父类Classloader。一个示例实现:
public Class loadClass(String name) throws ClassNotFoundException { if(name.equals("javax.lang.ClassIDontLike")){ throw new ClassNotFoundException("I'm sorry, Dave. I'm afraid I can't do that."); } return super.loadClass(name, false);}(当然,真正的实现可能比这复杂得多)
因为应用程序的类是通过此Classloader加载的,并且仅在需要时将loadClass()调用委托给父类classloader,所以可以将所需的任何类列入黑名单。
我很确定这是Google用于将其服务器中的类列入黑名单的方法。他们在特定的Classloader中加载每个应用程序。这也类似于Tomcat隔离不同Web应用程序的方式。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)