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. Spring Boot项目的Logback配置文件使用yaml格式

    1.普通的Spring项目使用logback默认用properties文件做为配置变量. 2.如果非要用yaml文件,那么可以转成Spring Boot项目,天生无缝结合 3.没办法,如果项目配置文件 ...

  2. Syncovery 是目前功能最为强大的实时自动备份工具

    Syncovery Pro(原名叫做Super Flexible Synchronizer) 是目前功能最为强大的实时自动备份工具,连FTP.WebDAV等全部支持! 最近从V6开始改用比较好记.易懂 ...

  3. INTEL SSD SMART 性能 E8 E9 转

    如题今天研究了一下怎么看Intel SSD Toolbox里边显示的Smart信息.首先说,查看Intel SSD smart信息最好最方便的当然就是自家的工具箱,用其他工具查看不是不可以,但是很多数 ...

  4. blkblock 2工具

    http://blog.yufeng.info/archives/tag/blktrace

  5. Delphi TClientDataSet的使用

    1.TClientDataSet的基本属性和方法介绍 1).FieldDefs: 字段定义列表属性 开发者可通过单击属性编辑器中该属性编辑按钮,或在该控件上单击右键选择弹出菜单中的"Fiel ...

  6. [Node.js]NET模块

    摘要 net模块提供了一些用于底层的网络通信的小工具,包含了创建服务器和客户端的方法.可以使用该模块模拟请求等操作. net模块 引入net模块 var net=require("net&q ...

  7. Ext.state.Manager.setProvider(new Ext.state.CookieProvider())

    Ext.state.Manager.setProvider(new Ext.state.CookieProvider()) 初始化Ext状态管理器,在Cookie中记录用户的操作状态,如果不启用,象刷 ...

  8. Unity3D脚本批量打包渠道包

    最近在研究Unity3D脚本批量打包,比如在Android平台下各种不同分辨率和不同内存大小的机器,可能还有不同的渠道包,不同渠道可能用的SDK都不一样,这一切的一切都表明你的代码无法做到自适应的,除 ...

  9. 测试 Nginx 作为前端下各种模式的性能

    测试环境: 1:Nginx 独立处理静态面页请求 5000,开了60个线程 2:Nginx作为前端请求转给 Weblogic 12c 处理 (Spring 4.0平台下的动态面页效果如图) 3:Ngi ...

  10. MySQL Workbench update语句错误Error Code: 1175.

    rom:http://www.tuicool.com/articles/NJ3QRz MySQL update error: Error Code: 1175. You are using safe ...