Runtime.getRuntime().exec 路径包含空格
1. 现象
java代码通过Runtime.getRuntime().exec删除linux上的目录,如果路径信息不包含空格没有问题,但是有了空格,虽没有报错,但执行没有效果,文件夹删不掉。
2. 原因
Runtime.getRuntime().exec语法不支持空白符和管道符”|”
不支持空白符和管道符”
本文来源gao!%daima.com搞$代*!码$网9
|”的例子:
//包含空格 String cmd = "rm -fr test 1"; // 包含管道符 String cmd2 = "netstat -antup | grep ftp"; Process ps = Runtime.getRuntime().exec(cmd); ps.waitFor();
解决办法
如果直接在命令行执行的话,可以通过给完整的字符带上单引号或双引号,java代码用法不适用。
[root@EMS3 ~]# rm -rf "/root/test 1"
使用重载函数即可:
public Process exec(String cmdarray[])
String cmd = "rm -fr test 1"; // 或 String cmd2 = "netstat -antup | grep ftp"; Process ps = Runtime.getRuntime().exec(new String[]{"/bin/sh", "-c", cmd}); ps.waitFor(); ...
其中-c表示cmd是一条命令
/bin/sh -c注意事项
由于增加了-c 参数,并指定shell类型,因此需要确认shell的类型。因此根据实际环境的shell类型。
/bin/sh是什么?
shell编程是以”#“为注释,但对”#!/bin/sh”却不是。”#!/bin/sh”是对shell的声明,说明你所用的是那种类型的shell及其路径所在(#! /bin/sh 是指此脚本使用/bin/sh来解释执行,#!是特殊的表示符,其后面跟的是解释此脚本的shell的路径)。如果没有声明,则脚本将在默认的shell中执行,默认shell是由用户所在的系统定义为执行shell脚本的shell。
如果脚本被编写为在Kornshell ksh中运行,而默认运行shell脚本的为C shell csh,则脚本在执行过程中很可能失败。所以建议大家就把”#!/bin/sh”当成C 语言的main函数一样,写shell必须有,以使shell程序更严密。
Runtime.getRuntime().exec()产生阻塞的2个陷阱
背景
相信做java服务端开发的童鞋,经常会遇到Java应用调用外部命令启动一些新进程来执行一些操作的场景,这时候就会使用到Runtime.getRuntime().exec(),然而这个方法如果不谨慎很容易掉进陷阱。