2011-01-13 08:59:55 -07:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.File;
|
|
|
|
import java.io.FileInputStream;
|
|
|
|
|
|
|
|
public class DefineClass {
|
2011-01-15 10:33:56 -07:00
|
|
|
private static File findClass(String name, File directory) {
|
2011-01-13 08:59:55 -07:00
|
|
|
for (File file: directory.listFiles()) {
|
|
|
|
if (file.isFile()) {
|
2011-01-15 10:33:56 -07:00
|
|
|
if (file.getName().equals(name + ".class")) {
|
2011-01-13 08:59:55 -07:00
|
|
|
return file;
|
|
|
|
}
|
|
|
|
} else if (file.isDirectory()) {
|
2011-01-15 10:33:56 -07:00
|
|
|
File result = findClass(name, file);
|
2011-01-13 08:59:55 -07:00
|
|
|
if (result != null) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static byte[] read(File file) throws IOException {
|
|
|
|
byte[] bytes = new byte[(int) file.length()];
|
|
|
|
FileInputStream in = new FileInputStream(file);
|
|
|
|
try {
|
|
|
|
if (in.read(bytes) != (int) file.length()) {
|
|
|
|
throw new RuntimeException();
|
|
|
|
}
|
|
|
|
return bytes;
|
|
|
|
} finally {
|
|
|
|
in.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-01-15 10:33:56 -07:00
|
|
|
private static Class loadClass(String name) throws Exception {
|
|
|
|
return new MyClassLoader(DefineClass.class.getClassLoader()).defineClass
|
|
|
|
(name, read(findClass(name, new File(System.getProperty("user.dir")))));
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void testStatic() throws Exception {
|
|
|
|
loadClass("DefineClass$Hello")
|
|
|
|
.getMethod("main", String[].class).invoke(null, (Object) new String[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void testDerived() throws Exception {
|
|
|
|
System.out.println
|
|
|
|
(String.valueOf
|
|
|
|
(((Base) loadClass("DefineClass$Derived").newInstance()).zip()));
|
|
|
|
}
|
|
|
|
|
2011-01-13 08:59:55 -07:00
|
|
|
public static void main(String[] args) throws Exception {
|
2011-03-15 13:43:36 -06:00
|
|
|
testStatic();
|
2011-01-15 10:33:56 -07:00
|
|
|
testDerived();
|
2011-01-13 08:59:55 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
private static class MyClassLoader extends ClassLoader {
|
|
|
|
public MyClassLoader(ClassLoader parent) {
|
|
|
|
super(parent);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Class defineClass(String name, byte[] bytes) {
|
2011-03-15 13:43:36 -06:00
|
|
|
return defineClass(name, bytes, 0, bytes.length);
|
2011-01-13 08:59:55 -07:00
|
|
|
}
|
|
|
|
}
|
2011-01-15 10:33:56 -07:00
|
|
|
|
|
|
|
public static class Hello {
|
|
|
|
public static void main(String[] args) {
|
|
|
|
System.out.println("hello, world!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public abstract static class Base {
|
|
|
|
public int foo;
|
2011-01-17 09:36:03 -07:00
|
|
|
public int[] array;
|
2011-01-15 10:33:56 -07:00
|
|
|
|
|
|
|
public void bar() { }
|
|
|
|
|
|
|
|
public abstract int zip();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class Derived extends Base {
|
|
|
|
public int zip() {
|
|
|
|
return 42;
|
|
|
|
}
|
|
|
|
}
|
2011-01-13 08:59:55 -07:00
|
|
|
}
|