• java 代码执行cmd 返回值异常 (关于JAVA Project.waitfor()返回值是1)


    关于JAVA Project.waitfor()返回值是1

    Project.waitfor()返回值是1,找了很久从网上没有发现关于1的说明。

    这时对源代码调试了一下,发现Project=null.而去根目录下点击被调用的bat文件发现也可以被正确执行。

    这时想到应该将标准错误流的信息打印出来,发现是bat文件的路径只获取到了第一个空格前。所以问题的原因是空格导致文件路径不能被获取。

     原先的代码

    String batpath = file.getCanonicalPath() + "
    esources
    unTest.bat";    //run bat file    Process project = Runtime.getRuntime().exec("cmd.exe /c " + batpath);    int exitcode=project.waitFor();    //kill the process    project.destroy();    logger.info(exitcode);  

     修改后的代码

    //run bat file    Process project = Runtime.getRuntime().exec("cmd.exe /c " + batpath.replaceAll(" ", "" ""));  

     此次解决问题的经验是:

    不要盲目的先去网上找答案,要先将自己的程序调试一下,将错误信息打印出来,然后针对错误信息有针对性的去网上找答案。这样做比较有效。

    自己结论:

    java 代码中调用cmd 命令执行 mysql 脚本结果 cmd 命令返回结果为1的问题:

    Process process = Runtime.getRuntime().exec(cmd);
    int waitFor = process.waitFor();
    上边waitFor值为1,而值为0才是执行正常,那我怎么才能知道这个执行结果是因为什么出错的呢?可以把出错信息打印出来就行了,process对象 有一个异常流,打印一下就好了:
    FileInputStream errorStream = (FileInputStream)process.getErrorStream();
                InputStreamReader isr = new InputStreamReader(errorStream,"gbk");//读取
                System.out.println(isr.getEncoding());
                BufferedReader bufr = new BufferedReader(isr);//缓冲
                String line = null;
                while((line =bufr.readLine())!=null) {
                    System.out.println(line);
                }
                isr.close();
    

     结果发现打印的语句是:mysqldump  不是内部命令...  

    可以发现 执行结果不正确是因为 这个mysql的命令 没法使用造成的,去找这个原因就可以了。

    这个问题明显是mysql的环境变量中path路径没配mysql路径,但由于mysql软件安装时系统是默认配的,为啥这里还是不能用mysql命令,而c盘根目录却可以用的,最后查原因是需要重启电脑,intellj 中才能使用刚装的mysql服务。



  • 相关阅读:
    各种贴图
    d3d11devicecontext
    小记2
    Tom Ryaboi
    Tessellation
    关于图形学
    第一章实验
    控制输入框只接收数字及小数点
    JQuery控制文本框是否可以输入
    SQLSERVER中查询一个存储过程使用到的地方
  • 原文地址:https://www.cnblogs.com/wzhanke/p/4792495.html
Copyright © 2020-2023  润新知