實(shí)現步驟:
1.自定義一個(gè)Java類(lèi),該Java類(lèi)中定義一個(gè)方法來(lái)包含需要被運行的代碼。
2.動(dòng)態(tài)編譯剛剛生成的Java源碼,不在磁盤(pán)上生成源碼,而是直接編譯內存中的Java源碼。
3.動(dòng)態(tài)加載剛剛創(chuàng )建編譯的Java二進(jìn)制碼,編譯好的Java二進(jìn)制碼不是在磁盤(pán)上,而是放在內存中,并定義自己的類(lèi)加載器,負責加載內存中的class文件。
4.通過(guò)反射運行前一步加載的類(lèi)。
[java]
view plaincopyimport java.util.Arrays;
import javax.tools.SimpleJavaFileObject;
import javax.tools.JavaFileObject;
import javax.tools.JavaCompiler;
import javax.tools.ToolProvider;
import javax.tools.DiagnosticCollector;
import java.net.URI;
/**
* Description:
* <br/>網(wǎng)站: <a >瘋狂Java聯(lián)盟</a>
* <br/>Copyright (C), 2001-2010, Leeyohn
* <br/>This program is protected by copyright laws.
* <br/>Program Name:
* <br/>Date:
* @author Leeyohn leeyohn@hotmail.com
* @version 1.0
*/
public class MyClassLoader
extends ClassLoader
{
@Override
public Class<?> findClass(String str) throws ClassNotFoundException
{
JavaCompiler compiler = ToolProvider.getSystemJavaCompiler();
//用于診斷源代碼編譯錯誤的對象
DiagnosticCollector diagnostics = new DiagnosticCollector();
//內存中的源代碼保存在一個(gè)從JavaFileObject繼承的類(lèi)中
JavaFileObject file = new JavaSourceFromString("Temp", str.toString());
Iterable compilationUnits = Arrays.asList(file);
//建立一個(gè)編譯任務(wù)
JavaCompiler.CompilationTask task = compiler.getTask(null, null, null, null, null, compilationUnits);
//編譯源程序
boolean result = task.call();
if (result)
{
return Class.forName("Temp");
}
return null;
}
}
class JavaSourceFromString extends SimpleJavaFileObject
{
private String name;
private String code;
public JavaSourceFromString(String name, String code)
{
super(URI.create("string:///" + name.replace('.', '/') + Kind.SOURCE.extension), Kind.SOURCE);
this.code = code;
}
public CharSequence getCharContent(boolean ignoreEncodingErrors)
{
return code;
}
}
[c-sharp]
view plaincopyimport java.lang.reflect.Method;
/**
* Description:
* <br/>網(wǎng)站: <a >瘋狂Java聯(lián)盟</a>
* <br/>Copyright (C), 2001-2010, Leeyohn
* <br/>This program is protected by copyright laws.
* <br/>Program Name:
* <br/>Date:
* @author Leeyohn leeyohn@hotmail.com
* @version 1.0
*/
public class Eval
{
public static Object eval(String str) throws Exception
{
StringBuffer sb = new StringBuffer();
sb.append("public class Temp");
sb.append("{");
sb.append(" public Object getObject()");
sb.append(" {");
sb.append(" " + str + "return new Object();");
sb.append(" }");
sb.append("}");
//調用自定義類(lèi)加載器加載編譯在內存中class文件
Class clazz = new MyClassLoader().findClass(sb.toString());
Method method = clazz.getMethod("getObject");
//通過(guò)反射調用方法
return method.invoke(clazz.newInstance());
}
public static void main(String[] args) throws Exception
{
Object rval = eval("System.out.println(/"Hello World/");");
System.out.println(rval);
}
}