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. SGU 403 Game with points

    408. Game with points Time limit per test: 0.25 second(s)Memory limit: 65536 kilobytes input: standa ...

  2. mysql反向解析导致连接缓慢

    Content 0.序 1.问题 2.原因 3.解决办法 0.序 本文主要是记录Mysql安装在 VMWARE下,本地连接Mysql速度很慢的原因及解决办法. 1.问题 本地的一个网站使用mysql数 ...

  3. 不用windows不会死

    不用windows不会死 近期看到win8广告,仅仅要2999元. 事实上他们不知道,不用windows不但不会死,还会活得更好. 不信.你去问问那些非windows用户,他们是不是非常快乐?烦恼非常 ...

  4. C/C++服务器开发的必备利器–libconfig

    http://www.leoox.com/?p=311 程序肯定需要一份配置文件,要不然,自己的程序不是“可配置”的,自己都不好意思往“高大上”靠拢.言归正传,以前自己写代码,配置文件的读写都是各式各 ...

  5. appium+python自动化59-appium命令行参数

    Appium服务器参数 许多Appium 1.5服务器参数已被弃用,以支持--default-capabilities标志. 用法: node . [flags] help 1.cmd端口输入,app ...

  6. Deployment failure on Tomcat 7.x. Could not copy all resources to

    今天在网上部署项目的时候出现在了问题 tomcat一直部署不上 网上查了一下 原因记下来供大家查看 [plain] <span style="font-size:18px;" ...

  7. C语言编程规范

    C语言编程规范 6 函数与过程 6.1 函数的功能与规模设计 函数应当短而精美,而且只做一件事.不要设计多用途面面俱到的函数,多功能集于一身的函数,很可能使函数的理解.测试.维护等变得困难. 6.2 ...

  8. Nginx缓存使用官方教程及常见问题解答

    原文地址:http://www.kuqin.com/shuoit/20150804/347388.html 我们都知道,应用程序和网站一样,其性能关乎生存.但如何使你的应用程序或者网站性能更好,并没有 ...

  9. 数学图形(1.2)Sin曲线

    相关软件参见:数学图形可视化工具,使用自己定义语法的脚本代码生成数学图形.该软件免费开源.QQ交流群: 367752815 Sin曲线 vertices = x = *PI) to (*PI) y = ...

  10. C语言编译器不检查数组下标越界

    这两天被人问了一个问题说假如C/C++访问下表越界的数组元素会报错么,于是充满好奇心的我动手试了一下,WTF,果然没有报错,但是会给程序带来莫名其妙的结果(比如十次的循环但是变成了死循环,但八次却可以 ...