java调用linux命令解压gz

Python015

java调用linux命令解压gz,第1张

1.

将文件压缩为 .gz 格式,只能压缩文件:gzip ①、命令名称:gzip ②、英文原意:GNU zip ③、命令所在路径:/bin/gzip ④、执行权限:所有用户 ...

2.

将 .gz 文件解压:gunzip

命令名称:gunzip

以下方法支持Linux和windows两个系统的命令行调用。还用到了apache的lang工具包commons-lang3-3.1.jar来判断操作系统类型、也用到了和log4j-1.2.16.jar来打印日志。至于rm -rf 是否能成功删除文件,可以手动去调用命令行试试。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

private String callCmd(String cmd) throws InterruptedException, UnHandledOSException, ExecuteException {

if(SystemUtils.IS_OS_LINUX){

try {

// 使用Runtime来执行command,生成Process对象

Process process = Runtime.getRuntime().exec(

new String[] { "/bin/sh", "-c", cmd })

int exitCode = process.waitFor()

// 取得命令结果的输出流

InputStream is = process.getInputStream()

// 用一个读输出流类去读

InputStreamReader isr = new InputStreamReader(is)

// 用缓冲器读行

BufferedReader br = new BufferedReader(isr)

String line = null

StringBuilder sb = new StringBuilder()

while ((line = br.readLine()) != null) {

System.out.println(line)

sb.append(line)

}

is.close()

isr.close()

br.close()

return sb.toString()

} catch (java.lang.NullPointerException e) {

System.err.println("NullPointerException " + e.getMessage())

logger.error(cmd)

} catch (java.io.IOException e) {

System.err.println("IOException " + e.getMessage())

}

throw new ExecuteException(cmd + "执行出错!")

}

if(SystemUtils.IS_OS_WINDOWS){

Process process

try {

//process = new ProcessBuilder(cmd).start()

String[] param_array = cmd.split("[\\s]+")

ProcessBuilder pb = new ProcessBuilder(param_array)

process = pb.start()

/*process=Runtime.getRuntime().exec(cmd)*/

int exitCode = process.waitFor()

InputStream is = process.getInputStream()

InputStreamReader isr = new InputStreamReader(is)

BufferedReader br = new BufferedReader(isr)

String line

StringBuilder sb = new StringBuilder()

while ((line = br.readLine()) != null) {

System.out.println(line)

sb.append(line)

}

is.close()

isr.close()

br.close()

return sb.toString()

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace()

}

throw new ExecuteException(cmd + "执行出错!")

}

throw new UnHandledOSException("不支持本操作系统")

}

1.Java调用shell

Java语言以其跨平台性和简易性而著称,在Java里面的lang包里(java.lang.Runtime)提供了一个允许Java程序与该程序所运

行的环境交互的接口,这就是Runtime类,在Runtime类里提供了获取当前运行环境的接口。

其中的exec函数返回一个执行shell命令的子进程。exec函数的具体实现形式有以下几种:

public Process exec(String command) throws IOException

public Process exec(String command,String[] envp) throws

IOException

public Process exec(String command,String[] envp,File dir) throws

IOException

public Process exec(String[] cmdarray) throws IOException

public Process exec(String[] cmdarray, String[] envp) throws

IOException

public Process exec(String[] cmdarray, String[] envp,File dir)

throws IOException

我们在这里主要用到的是第一个和第四个函数,具体方法很简单,就是在exec函数中传递一个代表命令的字符串。exec函数返回的是一个Process类

型的类的实例。Process类主要用来控制进程,获取进程信息等作用。(具体信息及其用法请参看Java doc)。

1)执行简单的命令的方法:

代码如下:

上面的代码首先是声明了一个代表命令的字符串commands,它代表了ls -l

这个命令。之后我们用Runtime.getRuntime().exec(commands)来生成一个子进程来执行这个命令,如果这句话运行成功,则

命令 ls -l 运行成功(由于没有让它显示,不会显示ls -l

的结果)。后面的流操作则是获取进程的流信息,并把它们一行行输出到屏幕。2)执行带有参数的命令(尤其是参数需要用引号的)时则需要用String的数组来表示整个命令,而且要用转义符把引号的特殊含义去除,例如我们要执行

find / -name "*mysql*" -print 时,用如下代码

Java 可以通过 Runtime 调用Linux命令,形式如下:

Runtime.getRuntime().exec(command)

但是这样执行时没有任何输出,因为调用 Runtime.exec 方法将产生一个本地的进程,并返回一个Process子类的实例(注意:Runtime.getRuntime().exec(command)返回的是一个Process类的实例)该实例可用于控制进程或取得进程的相关信息。

由于调用 Runtime.exec 方法所创建的子进程没有自己的终端或控制台,因此该子进程的标准IO(如stdin,stdou,stderr)都通过 Process.getOutputStream(),Process.getInputStream(), Process.getErrorStream() 方法重定向给它的父进程了。

用户需要用这些stream来向子进程输入数据或获取子进程的输出,下面的代码可以取到 linux 命令的执行结果: