windowsexec怎么打开开exec

PHP启动windows应用程序、执行bat批处理、执行cmd命令的方法(exec、system函数详解)
exec 或者 system 都可以调用cmd 的命令
直接上代码:
/** 打开windows的计算器 */
exec('start C:WindowsSystem32calc.exe');
/** php生成windows的批处理文件后,再执行这个批处理文件*/
$filename = 't.bat';
$somecontent = 'C:
$somecontent .= 'cd "C:/Program Files/MySQL-Front"';
$somecontent .= '
start MySQL-Front.exe';
if (!$handle = fopen($filename, 'w')) {
&echo "不能打开文件 $filename";
/** 首先我们要确定文件存在并且可写*/
if (is_writable($filename)) {
&/** 那就是当我们使用fwrite()的时候,$somecontent将要写入的地方
&&将$somecontent写入到我们打开的文件中 。*/
&if (fwrite($handle, $somecontent) === FALSE) {
&&echo "不能写入到文件 $filename";
&echo "成功地将 $somecontent 写入到文件 $filename";
&fclose($handle);
&echo "文件 $filename 不可写";
exec($filename);
有一个遗留问题,就是exec()调用,php会一直执行,直到你关闭启动的应用程序,这样会造成php执行超时,不知道怎么解决这个问题,希望高手路过此地,留下答案!我日后解决了,也会更新到这里的!
以下来自资料
=================================================
php的内置函数exec,system都可以调用系统命令(shell命令),当然还有passthru,escapeshellcmd等函数。
在很多时候利用php的exec,system等函数调用系统命令可以帮助我们更好更快的完成工作。
注意:要想使用这二个函数 php.ini 中的安全模式必须关闭,要不然为了安全起见php是不让调用系统命令的。
先看一下php手册对这二个函数的解释:
exec --- 执行外部程式
语法 : string exec ( string command [, array &output [, int &return_var]] )
exec()执行给予的命令command,不过它并不会输出任何东西,它简单的从命令的结果中传回最后一行,如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru()这个函数。
如果有给予参数array,则指定的数组将会被命令所输出的每一行填满,注意 : 如果数组先前已经包含了一些元素的话,exec()将会把它附加在数组的后面,如果你不想要此函数附加元素的话,你可以在传递此数组给exec()之前呼叫unset()。
如果有给予参数array和return_var,则传回执行的状态命令将会写到这个变量。
注意: 如果你允许来自使用者输入的资料,可以传递到此函数,那么你应该使用escapeshellcmd( )来确定此使用者无法哄骗(trick)系统来执行武断的(arbitrary)命令。
注意: 如果你使用此函数来启动一个程式,而且希望在背景里(background)执行的时候离开它,你必须确定此程式的输出是转向(redirected)到一个文件或是一些输出的资料流,否则将会悬挂(hang)直到程式执行结束。
system --- 执行外部程式并且显示输出
语法:string system ( string command [, int &return_var] )
system( )执行给予的命令command,并且输出结果。如果有给予参数return_var,则执行命令的状态码将会写到这个变量。
注意: 如果你允许来自使用者输入的资料,可以传递到此函数,那么你应该使用escapeshellcmd( )来确定此使用者无法哄骗(trick)系统来执行武断的(arbitrary)命令。
注意: 如果你使用此函数来启动一个程式,而且希望在背景里(background)执行的时候离开它,你必须确定此程式的输出是转向(redirected)到一个文件或是一些输出的资料流,否则PHP将会悬挂(hang)直到程式执行结束。
如果PHP是运作成伺服器模组,在输出每一行后,system( )会试着自动地清除web伺服器的输出缓冲。
成功则传回命令的最后一行,失败则传回false。
如果你需要去执行一个命令,并且从命令去取得所有资料时,可以使用passthru( )这个函数。
这二个都是用来调用系统shell命令,
exec可以把执行的结果全部返回到$output函数里(数组),$status是执行的状态 0为成功 1为失败
systerm不需要提供$output函数,他是直接把结果返回出来,同样$return_var是执行的状态码 0为成功 1为失败
exec示例:
&$a = exec("dir", $out, $status);
&print_r($a);
&print_r($out);
&print_r($status);
system示例:
&$a = system("dir", $status);
&print_r($a);
&print_r($status);
上面说明看起来有点乱,运行两个例子后,你就会明白的!
【system】
set_time_limit(0);
define('ROOT_PATH', dirname(__FILE__));
include ROOT_PATH . '/include/global.func.php';
$cmdTest = 'ps -ef | grep magent';
$lastLine = system($cmdTest, $retVal);
write_log('$lastLine');
write_log($lastLine);
write_log('$retVal');
write_log($retVal);
++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++
root&&&&& & 0 16:28 pts/1&&& 00:00:00 grep magent
++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++
set_time_limit(0);
define('ROOT_PATH', dirname(__FILE__));
include ROOT_PATH . '/include/global.func.php';
$cmdTest = 'ps -ef | grep magent';
$lastLine = exec($cmdTest, $output, $retVal);
write_log('$lastLine');
write_log($lastLine);
write_log('$output');
write_log($output);
write_log('$retVal');
write_log($retVal);
++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++
root&&&&& & 0 16:25 pts/1&&& 00:00:00 grep magent
++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++
&&& [0] =& root&&&&& 2838&&&& 1& 0 15:39 ?&&&&&&& 00:00:00 magent -u root -n 51200 -l 192.168.137.100 -p 12001 -s 192.168.137.100:11211 -b 192.168.137.100:11212
&&& [1] =& root&&&&& & 0 16:25 pts/1&&& 00:00:00 sh -c ps -ef | grep magent
&&& [2] =& root&&&&& & 0 16:25 pts/1&&& 00:00:00 grep magent
++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++
如果需要详细的输出结果,那就用exec()吧!我一般用exec()执行外部命令!
http://php.net/manual/zh/function.system.php
http://php.net/manual/zh/function.exec.php
顶一下(0) 踩一下(0)
热门标签:symantec backup exec 2010r2 管理指南
扫扫二维码,随身浏览文档
手机或平板扫扫即可继续访问
symantec backup exec 2010r2 管理指南
举报该文档为侵权文档。
举报该文档含有违规或不良信息。
反馈该文档无法正常浏览。
举报该文档为重复文档。
推荐理由:
将文档分享至:
分享完整地址
文档地址:
粘贴到BBS或博客
flash地址:
支持嵌入FLASH地址的网站使用
html代码:
&embed src='/DocinViewer-4.swf' width='100%' height='600' type=application/x-shockwave-flash ALLOWFULLSCREEN='true' ALLOWSCRIPTACCESS='always'&&/embed&
450px*300px480px*400px650px*490px
支持嵌入HTML代码的网站使用
您的内容已经提交成功
您所提交的内容需要审核后才能发布,请您等待!
3秒自动关闭窗口win7系统怎么打开Windows PowerShell_百度知道
win7系统怎么打开Windows PowerShell
提问者采纳
powershell&Start Menu\system32\Windows\Windows PowerShellorclick &ProgramData\WindowsPowerShell&#92:\Accessories\v1;Programs&#92.0\Microsoft&#92.exeC;powershell%SystemRoot%&#92
其他类似问题
为您推荐:
powershell的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁一、遇到错误的情形 & &
& & 在用JS打开本地的文件(Microsoft Word)时,如果文件路径带有空格,那么winword命令会将路径错误的解析。JS代码如下:& & & &&
var filePath = "D:/Biview/Corpus/生理学第七版/第一章 绪论.docx";
var openDocObj = new ActiveXObject("WScript.Shell");
openDocObj.Run("winword.exe " + filePath + "");
& & 上面的代码中变量&filePath&中的&第一章 绪论&字符串由于中间有一个空格,所以用winword命令将会导致路径解析错误,最终就无法打开用户指定正确路径的文件。
二、尝试解决方案
& & 1、由于Windows把常用软件的名称和路径记录在注册表里。打开Windows运行的开始菜单,单击运行,输入&winword D:/Biview/Corpus/生理学第七版/第一章 绪论.docx&。可以看到解析的错误路径:
这个错误路径是你的word的安装文件路径,所以你安装的路径不同,这个错误路径也会不同。
& & 2、记得在Java程序中获取带空格路径的文件时,空格表示为&%20&,所以我也将空格替换为&%20&去尝试,输入&winword D:/Biview/Corpus/生理学第七版/第一章%20绪论.docx&,可以看到程序是没有将&%20&转义为空格:
& & 3、经过不断的尝试发现给路径加上引号可以正确的解析空格:
& & & & &a、不加&\&和磁盘名,输入:&winword "Biview/Corpus/生理学第七版/第一章 绪论.docx"&,默认寻找系统盘用户文件夹下。
& & & & &b、加&\&不加磁盘名,输入:&winword \"Biview/Corpus/生理学第七版/第一章 绪论.docx"&,默认寻找安装Microsoft Word的磁盘根目录下。
& & & & &c、加&\&不和磁盘名,输入:&winword D:\"Biview/Corpus/生理学第七版/第一章 绪论.docx"&,默认寻找指定盘符的目录下。
三、最终解决方案
//var filePath = "D:/Biview/Corpus/生理学第七版/第一章 绪论.docx";
var filePath = "D:\\\"Biview/Corpus/生理学第七版/第一章 绪论.docx\"";
四、测试环境
操作系统:64位和32位window7
Word版本:Microsoft Word 2010
IE版本:IE9
& & & & &1、如果是带空格路径的txt文件在运行里输入&notepad D:\Biview\Corpus\生理学第七版\第一章 绪论.txt&则可以正确打开。
& & & & &2、&winword&命令之后其他参数
   & & & & &/m宏名:启动Word后运行指定宏,并禁止运行AutoExec宏。
  & & & & & /n:启动Word而不打开任何文档。
  & & & & & /t(空格)文档名:启动Word后打开指定文档作为模板。
  & & & &  /a:禁止启动Word后加载项或载入共用模板,包括Normal。
   & & & & 但如果Word不能正常启动,命令行的方式就会很有帮助,如果由于宏病毒导致不能启动,则可以试试/m;如果是由于加载项所致,则可以试试/a。
Java技术交流、学习、讨论,QQ群:
阅读(...) 评论()

我要回帖

更多关于 exec文件怎么打开 的文章

 

随机推荐