执行调用Runtime.getRuntime期间Android-错误()EXEC() - 环境空-f

2019-07-31 05:04发布

我编了在Ubuntu 11.10的ffmpeg库,并将其移植Android上编译后的文件。
编译后我得到libffmpeg.so成功。 它被成功加载Android上。

我这样做在Ubuntu 11.10 Eclipse的Android模拟器。

我已经创建了一个小的测试应用程序,它作为命令提示从用户和显示结果接受命令。 (测试FFMPEG命令)

当我运行如“ls”,简单的命令“ls -l命令”它完美的作品。 但是当我简单地键入“cd MNT”“ffmpeg的 ”指挥和尝试运行它。 我警告在logcat中说,

08-26 16:44:52.553: W/System.err(5961): java.io.IOException: Error running exec(). Command: [ffmpeg] Working Directory: null Environment: null
08-26 16:44:52.573: W/System.err(5961):     at java.lang.ProcessManager.exec(ProcessManager.java:211)
08-26 16:44:52.573: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:168)
08-26 16:44:52.573: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:241)
08-26 16:44:52.583: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:184)
08-26 16:44:52.593: W/System.err(5961):     at ch.ffmpeg.reversit.MainActivity.Execute(MainActivity.java:61)
08-26 16:44:52.593: W/System.err(5961):     at ch.ffmpeg.reversit.MainActivity$1.onClick(MainActivity.java:46)
08-26 16:44:52.593: W/System.err(5961):     at android.view.View.performClick(View.java:3480)
08-26 16:44:52.593: W/System.err(5961):     at android.view.View$PerformClick.run(View.java:13983)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Handler.handleCallback(Handler.java:605)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Handler.dispatchMessage(Handler.java:92)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Looper.loop(Looper.java:137)
08-26 16:44:52.614: W/System.err(5961):     at android.app.ActivityThread.main(ActivityThread.java:4340)
08-26 16:44:52.624: W/System.err(5961):     at java.lang.reflect.Method.invokeNative(Native Method)
08-26 16:44:52.624: W/System.err(5961):     at java.lang.reflect.Method.invoke(Method.java:511)
08-26 16:44:52.634: W/System.err(5961):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
08-26 16:44:52.634: W/System.err(5961):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
08-26 16:44:52.644: W/System.err(5961):     at dalvik.system.NativeStart.main(Native Method)
08-26 16:44:52.644: W/System.err(5961): Caused by: java.io.IOException: Permission denied
08-26 16:44:52.674: W/System.err(5961):     at java.lang.ProcessManager.exec(Native Method)
08-26 16:44:52.674: W/System.err(5961):     at java.lang.ProcessManager.exec(ProcessManager.java:209)
08-26 16:44:52.684: W/System.err(5961):     ... 16 more

这里是我的代码:

imports;
public class MainActivity extends Activity {
    String com;
    Process process;
    EditText command;
    Button run;
    RelativeLayout main_layout;

    static {
     System.loadLibrary("ffmpeg");
    }

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

       //find view 
       command=(EditText)findViewById(R.id.command);
       run=(Button)findViewById(R.id.run);

        run.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                com=command.getText().toString();
                try {
                    Execute();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

            }
        }); 

    }

    public void Execute() throws IOException, InterruptedException{
        process=Runtime.getRuntime().exec(com);
        // process = pb.command(com).redirectErrorStream(true).start();

        if(process!=null)
        ShowOutput();
        else
        Toast.makeText(getBaseContext(),"Null Process",Toast.LENGTH_LONG).show();
    }

    public void ShowOutput() throws IOException, InterruptedException{
        String s,text="",errors="";
        BufferedReader stdInput = new BufferedReader(new 
                InputStreamReader(process.getInputStream()));

           BufferedReader stdError = new BufferedReader(new 
                InputStreamReader(process.getErrorStream()));


           TextView output=(TextView)findViewById(R.id.output);
           TextView error=(TextView)findViewById(R.id.error);

            while ((s = stdInput.readLine()) != null) {
                   text+=s.toString()+"\n";
                   System.out.println("Error: "+s);
               }

         output.setText(text);
         text="";
           // read any errors from the attempted command
           System.out.println("Here is the standard error of the command (if any):\n");
           while ((s = stdError.readLine()) != null) {
               text+=s.toString()+"\n";
               System.out.println("Error: "+s);
           }

           error.setText(text);

           error.setMovementMethod(new ScrollingMovementMethod());
           output.setMovementMethod(new ScrollingMovementMethod());

           stdInput.close();
           stdError.close();

           process.waitFor();
           process.getOutputStream().close();
           process.getInputStream().close();
           process.getErrorStream().close(); 
           process.destroy();


    }

}

我甚至尝试process = pb.command(com).redirectErrorStream(true).start(); 执行。 它给了我同样的错误,但这个时环境[ANDROID_SOCKET_Zygot]唧唧歪歪..


编辑1:我用的OpenJDK在Ubuntu

帮帮我 !!

Answer 1:

有一个相当庞大的身躯[机器人] [ffmpeg的]讨论和如何是的...

调用非解锁装置的ffmpeg(即一般用户的应用程序)的正常途径是使用NDK和C浪的整合,其中在Java中你做一个包装CLI的东西,PARMS该集合通常方法调用JNI层将提供给ffmpeg的可执行文件的界面。

Android的通话step1.android的例子是...

             new FFMpegTask().execute(invoke_lib_path,"ffmpeg", "-y", 
                    "-i", Picture.getPath(), "-i", recordFilePath,
                    "-vcodec", "mpeg4", "-s", siz,
                    "-r", "15", "-b:v", "200k",
                    "-acodec", "copy", "-f", "3gp"
                    ,pathOut);

Step2.c

JNIEXPORT空隙JNICALL Java_com _..._ naRun(JNIEnv的*的env,jobject OBJ,jobjectArray参数){INT I = 0; int argc = 0; INT的argc = 0; char **argv = NULL; 字符** argv的= NULL;

if (args != NULL) { argc = ( env)->GetArrayLength(env, args); 如果(参数!= NULL){的argc =(ENV) - > GetArrayLength(ENV,参数); argv = (char * ) malloc(sizeof(char *) * argc); 的argv =(字符*)malloc的(的sizeof(字符*)*的argc);

  for(i=0;i<argc;i++) { jstring str = 

(jstring)(*env)->GetObjectArrayElement(env, args, i); (的jstring)(* ENV) - > GetObjectArrayElement(ENV,指定参数时,ⅰ); argv[i] = (char *)(*env)->GetStringUTFChars(env, str, NULL); 的argv [I] =(字符*)(* ENV) - > GetStringUTFChars(ENV,STR,NULL); } } int j = 0; }}诠释J = 0; J =主(的argc,argv的); }

尝试使用的Java的Runtime.exec()型CLI调用是什么,我会叫一个黑客,这将是你的时间很大的浪费。

通过.apk文件使用NDK和正常的包装,你都保证有较高的东西,像部署设备上的处理器架构和FFmpeg的是为建立在处理器之间的可靠性和集成。

尝试阅读roman10的介绍

然后,你可以尝试依靠面包屑从大量的谁已经建立的ffmpeg Android的人..也就是谷歌“Android的ffmpeg的”

如果你是植根并已编译的可执行文件,那么你可以得到一个壳,并使用亚行CLI援引。 请注意,是不是像使用Java作为的Runtime.exec调用的包装。

亚行推动的ffmpeg /数据/本地/的ffmpeg / ffmpeg的

./ffmpeg -codecs



Answer 2:

据我所知,您不能使用cd命令。 这是一个bash指令,也没有可执行的CD。 我猜的ffmpeg不能正常工作,因为权限。 亚行壳做搭配chmod 777 ffmpeg的,然后再试一次



Answer 3:

我可能是有点晚

java.io.IOException: Error running exec(). Command: [ffmpeg] Working Directory: null Environment: null

它明确地表示ffmpeg的文件找不到。 之前exexuting任何命令首先检查文件是否存在于所提到的位置。

boolean ifFileExists = new File(*path_of_ffmpeg_file*).exists();


       if(ifFileExists==false){
// code to write file in phone
    }
method(commandToExecute);


文章来源: Android- Error during executing Runtime.getRuntime().exec() - Environment Null -ffmpeg