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

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

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

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

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

原先的代码

String batpath = file.getCanonicalPath() + "\resources\runTest.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服务。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值