上一篇:如何有效的保护JAVA程序 >>
在java调试中如何获得被装载类的实际路径
java.security.ProtectionDomain;
CodeSource 可以给出类的原始URL的位置,但并不是每个类都有CodeSource。如果类通过引导类装载器装载,CodeSource为空。
import java.lang.reflect.Method;
import java.net.URL;
import java.security.CodeSource;
import java.security.ProtectionDomain;
public class Debug
{
public static void displayClassInfo(Class clazz, StringBuffer results)
{
displayClassInfo(clazz, results, true);
}
public static void displayClassInfo(Class clazz, StringBuffer results,
boolean showParentClassLoaders)
{
ClassLoader cl = clazz.getClassLoader();
results.append("\n"+clazz.getName()+"("+Integer.toHexString(clazz.hashCode())+").ClassLoader="+cl);
ClassLoader parent = cl;
while( parent != null )
{
results.append("\n.."+parent);
URL[] urls = getClassLoaderURLs(parent);
int length = urls != null ? urls.length : 0;
for(int u = 0; u < length; u ++)
{
results.append("\n...."+urls[u]);
}
if( showParentClassLoaders == false )
break;
if( parent != null )
parent = parent.getParent();
}
CodeSource clazzCS = clazz.getProtectionDomain().getCodeSource();
if( clazzCS != null )
results.append("\n++++CodeSource: "+clazzCS);
else
results.append("\n++++Null CodeSource");
results.append("\nImplemented Interfaces:");
Class[] ifaces = clazz.getInterfaces();
for(int i = 0; i < ifaces.length; i ++)
{
Class iface = ifaces[i];
results.append("\n++"+iface+"("+Integer.toHexString(iface.hashCode())+")");
ClassLoader loader = ifaces[i].getClassLoader();
results.append("\n++++ClassLoader: "+loader);
ProtectionDomain pd = ifaces[i].getProtectionDomain();
CodeSource cs = pd.getCodeSource();
if( cs != null )
results.append("\n++++CodeSource: "+cs);
else
results.append("\n++++Null CodeSource");
}
}
/** Use reflection to access a URL[] getURLs or ULR[] getAllURLs method so
that non-URLClassLoader class loaders, or class loaders that override
getURLs to return null or empty, can provide the true classpath info.
*/
public static URL[] getClassLoaderURLs(ClassLoader cl)
{
URL[] urls = {};
try
{
Class returnType = urls.getClass();
Class[] parameterTypes = {};
Method getURLs = cl.getClass().getMethod("getURLs", parameterTypes);
if( returnType.isAssignableFrom(getURLs.getReturnType()) )
{
Object[] args = {};
urls = (URL[]) getURLs.invoke(cl, args);
}
}
catch(Exception ignore)
{
}
return urls;
}
}
相关文章:
- · Java 性能优化技巧集锦 (6)
- · Java 性能优化技巧集锦 (5)
- · Java 性能优化技巧集锦 (3)
- · Java 性能优化技巧集锦 (2)
- · Java 性能优化技巧集锦 (1)
- · java_util_test
- · Java_util_package
- · JAVA与正则表达式(2年级之1)
- · Java的建造设计模式
- · java初学者必读-经验总结
- · 我的java开发环境配置
- · Visual Studio:针对 Java 开发人员的 C# 编程语言
- · 用java实现外部调用exe文件
- · JAVA 与C#构造函数执行顺序的不同之处.
- · Java性能
- · Java开发源缓存系统的介绍
- · 使用Java Server Faces技术自定义组件
- · JAVA 的MD5加密算法源代码
- · java初学者必读-经验总结
- · Java学习从入门到精通.过程篇
- · 对代理模式与Java动态代理类的理解
- · Java学习从入门到精通.书籍篇
- · Java数组学习心得,欢迎拍砖
- · c#与java的区别---读书
- · Java修饰符之static
- · java工具之javadoc和jar浅学 选择自 shaobotao 的 Blog
- · java设计模式之创建模式--singleton
- · Java软件开发学习笔记(三)
- · Java动态调用类方法的应用
- · 用ANT 开发 Java 程序
- · Java单体测试工具cactus使用指南
- · Java实现分类文件拷贝
- · Java中的Sizeof(二)
- · JAVA 的MD5加密算法源代码
- · Java软件开发学习笔记(二)
- · Java的文件 读和写
- · 使用Java与XSLT的10条技巧
- · Java常见问题总结
