JDK5.0特性,使用ProcessBuilder执行本地命令
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
/**
* 在J2SE5.0之前使用Runtime的exec方法执行本地命令.
* 在J2Se5.0之后,可以使用ProcessBuilder执行本地命令
* 它提供的功能更加丰富,能够设置设置工作目录、环境变量等
* 本例PorcessBuilder执行Windows操作系统的"ipconfig/all"命令,获取本机网卡的MAC地址
*/
/**关键技术剖析
* 用本命令名和命令的参数选项构造ProcessBuilder对象,它的start方法执行命令,启动一个进程,返回一个Process对象
* ProcessBuilder的environment方法获得运行进程的环境变量,得到一个Map,可以修改环境变量
* ProcessBuilder的directory方法切换工作目录
* Process的getInputStream方法获得进程的标准输出流,getErrorStream方法获得进程的错误输出流
*/
public class UsingProcessBuilder {
/**获取Windows系统下的网卡的MAC地址*/
public static List<String> getPhysicalAddress(){
Process p = null;
List<String> address = new ArrayList<String>(); //物理网卡列表
try{
p = new ProcessBuilder("ipconfig","/all").start(); //执行ipconfig/all命令
}catch(IOException e){
return address;
}
byte[] b = new byte[1024];
int readbytes = -1;
StringBuffer sb = new StringBuffer();
//读取进程输出值
//在JAVA IO中,输入输出是针对JVM而言,读写是针对外部数据源而言
InputStream in = p.getInputStream();
try{
while((readbytes = in.read(b)) != -1){
sb.append(new String(b,0,readbytes));
}
}catch(IOException e1){
}finally {
try{
in.close();
}catch (IOException e2){
}
}
//以下是分析输出值,得到物理网卡
String rtValue = sb.toString();
int i = rtValue.indexOf("Physical Address. . . . . . . . . :");
while (i > 0){
rtValue = rtValue.substring(i + "Physical Address. . . . . . . . . :".length());
address.add(rtValue.substring(1,18));
i = rtValue.indexOf("Physical Address. . . . . . . . . :");
}
return address;
}
/**执行自定义的一个命令,该命令放在C:/temp下,并且需要两个环境变量的支持*/
public static boolean executeMyCommand1(){
//创建系统进程创建器
ProcessBuilder pb = new ProcessBuilder("myCommand","myArg1","myArg2");
Map<String, String> env = pb.environment(); //获得进程的环境
//设置和去除环境变量
env.put("VAR1", "myValue");
env.remove("VAR0");
env.put("VAR2", env.get("VAR1") + ";");
//迭代环境变量,获取属性名和属性值
Iterator it=env.keySet().iterator();
String sysatt = null;
while(it.hasNext())
{
sysatt = (String)it.next();
System.out.println("System Attribute:"+sysatt+"="+env.get(sysatt));
}
pb.directory(new File("C:/temp"));
try{
Process p = pb.start(); //得到进程实例
//等待进程执行完毕
if(p.waitFor() != 0){
//如果进程运行结果不为0,表示进程是错误退出的
//获得进程实例的错误输出
InputStream error = p.getErrorStream();
//do something
}
InputStream sdin = p.getInputStream(); //获得进程实例的标准输出
//do something
}catch(IOException e){
}catch(InterruptedException e){
}
return true;
}
public static void executeMyCommand2(){
ProcessBuilder pb = null;
String sysatt = null;
try
{
//创建一个进程示例
pb = new ProcessBuilder("cmd.exe");
//获取系统参数并打印显示
Map<String, String> env = pb.environment();
Iterator it=env.keySet().iterator();
while(it.hasNext())
{
sysatt = (String)it.next();
System.out.println("System Attribute:"+sysatt+"="+env.get(sysatt));
}
//设置工作目录
pb.directory(new File("d://myDir"));
Process p = pb.start();
//将要执行的Windows命令写入
BufferedWriter bw=new BufferedWriter(newOutputStreamWriter(p.getOutputStream()));
//'/r/n'是必须写入的
bw.write("test.bat /r/n");
bw.write("ping -t www.yahoo.com.cn /r/n");
//flush()方法是必须调用的
bw.flush();
//将执行结果打印显示
InputStream is = p.getInputStream();
InputStreamReader isr = new InputStreamReader(is, "GBK");
BufferedReader br = new BufferedReader(isr);
String line;
while ((line = br.readLine()) != null)
{
System.out.println(line);
}
}
catch (Exception e)
{
e.printStackTrace();
}
}
public static void main(String[] args){
List<String> address = UsingProcessBuilder.getPhysicalAddress();
for(String add : address){
System.out.printf("物理网卡地址: %s%n",add);
}
executeMyCommand1();
executeMyCommand2();
}
}
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291460.html
JDK5.0特性,使用ProcessBuilder执行本地命令的更多相关文章
- 7.使用ProcessBuilder执行本地命令(转)
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...
- ProcessBuilder执行本地命令
/**关键技术剖析 * 用本命令名和命令的参数选项构造ProcessBuilder对象,它的start方法执行命令,启动一个进程,返回一个Process对象 * ProcessBuilder的envi ...
- JDK5.0 特性-线程任务执行架构 ScheduledExecutorService
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html import java.util.concurrent.Callable ...
- JAVA中ProcessBuilder执行cmd命令找不到路径的解决方法
今天遇到了一个很奇葩的问题,终于解决了,记一下,以做备忘. 前提条件:工程路径在D盘下 cmd要执行的可执行文件路径不在D盘下 然后...出事了............................ ...
- JDK5.0 特性-线程锁Lock
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...
- JDK5.0特性-线程 Callable和Future
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...
- JDK5.0 特性 监控与管理虚拟机
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html import java.lang.management.ClassLoa ...
- JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue
来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...
- JDK5.0 特性-线程同步装置之Semaphore
来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html import java.util.ArrayList; import j ...
随机推荐
- SGU 403 Game with points
408. Game with points Time limit per test: 0.25 second(s)Memory limit: 65536 kilobytes input: standa ...
- mysql反向解析导致连接缓慢
Content 0.序 1.问题 2.原因 3.解决办法 0.序 本文主要是记录Mysql安装在 VMWARE下,本地连接Mysql速度很慢的原因及解决办法. 1.问题 本地的一个网站使用mysql数 ...
- 不用windows不会死
不用windows不会死 近期看到win8广告,仅仅要2999元. 事实上他们不知道,不用windows不但不会死,还会活得更好. 不信.你去问问那些非windows用户,他们是不是非常快乐?烦恼非常 ...
- C/C++服务器开发的必备利器–libconfig
http://www.leoox.com/?p=311 程序肯定需要一份配置文件,要不然,自己的程序不是“可配置”的,自己都不好意思往“高大上”靠拢.言归正传,以前自己写代码,配置文件的读写都是各式各 ...
- appium+python自动化59-appium命令行参数
Appium服务器参数 许多Appium 1.5服务器参数已被弃用,以支持--default-capabilities标志. 用法: node . [flags] help 1.cmd端口输入,app ...
- Deployment failure on Tomcat 7.x. Could not copy all resources to
今天在网上部署项目的时候出现在了问题 tomcat一直部署不上 网上查了一下 原因记下来供大家查看 [plain] <span style="font-size:18px;" ...
- C语言编程规范
C语言编程规范 6 函数与过程 6.1 函数的功能与规模设计 函数应当短而精美,而且只做一件事.不要设计多用途面面俱到的函数,多功能集于一身的函数,很可能使函数的理解.测试.维护等变得困难. 6.2 ...
- Nginx缓存使用官方教程及常见问题解答
原文地址:http://www.kuqin.com/shuoit/20150804/347388.html 我们都知道,应用程序和网站一样,其性能关乎生存.但如何使你的应用程序或者网站性能更好,并没有 ...
- 数学图形(1.2)Sin曲线
相关软件参见:数学图形可视化工具,使用自己定义语法的脚本代码生成数学图形.该软件免费开源.QQ交流群: 367752815 Sin曲线 vertices = x = *PI) to (*PI) y = ...
- C语言编译器不检查数组下标越界
这两天被人问了一个问题说假如C/C++访问下表越界的数组元素会报错么,于是充满好奇心的我动手试了一下,WTF,果然没有报错,但是会给程序带来莫名其妙的结果(比如十次的循环但是变成了死循环,但八次却可以 ...