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 ...
随机推荐
- Spring Boot项目的Logback配置文件使用yaml格式
1.普通的Spring项目使用logback默认用properties文件做为配置变量. 2.如果非要用yaml文件,那么可以转成Spring Boot项目,天生无缝结合 3.没办法,如果项目配置文件 ...
- Syncovery 是目前功能最为强大的实时自动备份工具
Syncovery Pro(原名叫做Super Flexible Synchronizer) 是目前功能最为强大的实时自动备份工具,连FTP.WebDAV等全部支持! 最近从V6开始改用比较好记.易懂 ...
- INTEL SSD SMART 性能 E8 E9 转
如题今天研究了一下怎么看Intel SSD Toolbox里边显示的Smart信息.首先说,查看Intel SSD smart信息最好最方便的当然就是自家的工具箱,用其他工具查看不是不可以,但是很多数 ...
- blkblock 2工具
http://blog.yufeng.info/archives/tag/blktrace
- Delphi TClientDataSet的使用
1.TClientDataSet的基本属性和方法介绍 1).FieldDefs: 字段定义列表属性 开发者可通过单击属性编辑器中该属性编辑按钮,或在该控件上单击右键选择弹出菜单中的"Fiel ...
- [Node.js]NET模块
摘要 net模块提供了一些用于底层的网络通信的小工具,包含了创建服务器和客户端的方法.可以使用该模块模拟请求等操作. net模块 引入net模块 var net=require("net&q ...
- Ext.state.Manager.setProvider(new Ext.state.CookieProvider())
Ext.state.Manager.setProvider(new Ext.state.CookieProvider()) 初始化Ext状态管理器,在Cookie中记录用户的操作状态,如果不启用,象刷 ...
- Unity3D脚本批量打包渠道包
最近在研究Unity3D脚本批量打包,比如在Android平台下各种不同分辨率和不同内存大小的机器,可能还有不同的渠道包,不同渠道可能用的SDK都不一样,这一切的一切都表明你的代码无法做到自适应的,除 ...
- 测试 Nginx 作为前端下各种模式的性能
测试环境: 1:Nginx 独立处理静态面页请求 5000,开了60个线程 2:Nginx作为前端请求转给 Weblogic 12c 处理 (Spring 4.0平台下的动态面页效果如图) 3:Ngi ...
- MySQL Workbench update语句错误Error Code: 1175.
rom:http://www.tuicool.com/articles/NJ3QRz MySQL update error: Error Code: 1175. You are using safe ...