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执行本地命令的更多相关文章

  1. 7.使用ProcessBuilder执行本地命令(转)

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...

  2. ProcessBuilder执行本地命令

    /**关键技术剖析 * 用本命令名和命令的参数选项构造ProcessBuilder对象,它的start方法执行命令,启动一个进程,返回一个Process对象 * ProcessBuilder的envi ...

  3. JDK5.0 特性-线程任务执行架构 ScheduledExecutorService

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html import java.util.concurrent.Callable ...

  4. JAVA中ProcessBuilder执行cmd命令找不到路径的解决方法

    今天遇到了一个很奇葩的问题,终于解决了,记一下,以做备忘. 前提条件:工程路径在D盘下 cmd要执行的可执行文件路径不在D盘下 然后...出事了............................ ...

  5. JDK5.0 特性-线程锁Lock

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...

  6. JDK5.0特性-线程 Callable和Future

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...

  7. JDK5.0 特性 监控与管理虚拟机

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html import java.lang.management.ClassLoa ...

  8. JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue

    来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...

  9. JDK5.0 特性-线程同步装置之Semaphore

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html import java.util.ArrayList; import j ...

随机推荐

  1. vue过滤器在v2.0版本用法

    vue 1.x 的写法在  vue 2.x版本已经废除 vue 1.x 写法 <body> <div id="app"> {{message | capit ...

  2. HP Microserver Gen8 Processor FAQ

    http://homeservershow.com/forums/index.php?/topic/6596-hp-microserver-gen8-processor-faq/ This guide ...

  3. 使用jdbc的缺点

    使用jdbc开发时有以下缺点 1,数据库连接,使用时就创建,不使用就释放,对数据库进行频繁连接开关和关闭,造成数据库资源浪费,影响数据库的性能 解决:使用数据库连接池管理数据库的连接 2,sql语句使 ...

  4. .NET:为什么需要逆变和协变

    为啥需要协变和逆变? 我目前想到的理由是:逆变和协变的目的是支持多态. 一个小例子 不明白为啥输出的是false和true. using System; using System.Collection ...

  5. Java 复制大文件方式(nio2 FileChannel 拷贝文件能力测试)

    目前为止,我们已经学习了很多 Java 拷贝文件的方式,除了 FileChannel 提供的方法外,还包括使用 Files.copy() 或使用字节数组的缓冲/非缓冲流.那个才是最好的选择呢?这个问题 ...

  6. 解决sqoop报错:java.lang.OutOfMemoryError: Java heap space

    报错栈: -- ::, INFO [main] org.apache.sqoop.mapreduce.db.DBRecordReader: Executing query: = ) AND ( = ) ...

  7. IIS HTTPS 禁用不安全的SSL2.0

    禁用: HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\Schannel\Protocols 验证:

  8. java静态代码分析工具infer

    infer是一个静态代码分析工具,探测bugs. 主要支持Java.C/C++ 安装:brew install infer 在线展示:https://codeboard.io/projects/115 ...

  9. Mysql 监控 支持 mysql 多实例自动发现以及主从监控

    在[/usr/local/zabbix327/bin] 目录下新建python文件,并增加执行权限,如下: #!/usr/bin/env /usr/bin/python # _*_ coding:ut ...

  10. linux下永久添加静态路由

    在linux下永久添加静态路由有两种方法: 添加路由的命令: 1,route add route add -net 192.56.76.0 netmask 255.255.255.0 dev eth0 ...