Aquí es lo que funciona para mí:
test_p.py:
def foo():
print 'test from Python'
TestJ.java:
import org.python.core.PyFrame;
import org.python.core.PyFunctionTable;
import org.python.util.PythonInterpreter;
public class TestJ
{
public static void main(String[] args)
{
final PythonInterpreter interpreter = new PythonInterpreter();
interpreter.exec("import sys");
try
{
final Class<?> clazz = Class.forName("test_p$py");
final java.lang.reflect.Constructor constructor
= clazz.getConstructor(String.class);
final PyFunctionTable module = (PyFunctionTable)constructor.newInstance("");
final java.lang.reflect.Method method
= clazz.getDeclaredMethod("foo$1",
PyFrame.class,
org.python.core.ThreadState.class);
method.invoke(module,
(PyFrame)interpreter.eval("sys._getframe()").__tojava__(PyFrame.class),
org.python.core.Py.getThreadState());
}
catch (final ClassNotFoundException e)
{ e.printStackTrace(); }
catch (final NoSuchMethodException e)
{ e.printStackTrace(); }
catch (final InstantiationException e)
{ e.printStackTrace(); }
catch (final IllegalAccessException e)
{ e.printStackTrace(); }
catch (final java.lang.reflect.InvocationTargetException e)
{ e.printStackTrace(); }
}
}
Compilar test_p.py en test_p $ py.class :
$JYTHON_HOME/jython $JYTHON_HOME/Lib/compileall.py .
Mover test_p.py fuera del camino, para demostrar que no se está utilizando:
mkdir hidden
mv test_p.py hidden/
Compilar:
javac -cp $JYTHON_HOME/jython.jar TestJ.java
prueba:
java -cp $JYTHON_HOME/jython.jar:. TestJ
Salida:
test from Python
El compilador pypy probablemente sea una mejor apuesta desde una perspectiva de ofuscación. Desafortunadamente, es muy difícil de usar. – Antimony