首页 > 编程技术 > php

PHP调用linux命令详细说明

发布时间:2016-11-25 15:56

/*
在php教程中调用linux命令的函数是
string   exec(string   command,   string   [array],   int   [return_var]);

exec( "vpopmail ");

echo exec('whoami');

再看一实例

function exec_enabled() {
  $disabled = explode(', ', ini_get('disable_functions'));
  return !in_array('exec', $disabled);
}

<?php
$tmp = exec("c:\Image\gm.exe convert c:\Image\file1.tiff c:\Image\file1.jpg", $results);
?>

还有一种命令是

php通过函数system()调用系统命令。

string system ( string $command [, int &$return_var ] )

实例

system('asterisk -vvvvvvvvvvvc');

system()是一样的函数C的,它执行给定的命令和输出结果的版本。该system()的调用也尝试自动刷新网页服务器的输出缓冲器在每个输出行如果PHP运行作为服务器模块。如果你需要执行一个命令,并已全部通过直接从背面没有任何干扰的命令数据,使用passthru()函数。


$last_line = system('ls', $retval);


function my_exec($cmd, $input='')
         {$proc=proc_open($cmd, array(0=>array('pipe', 'r'), 1=>array('pipe', 'w'), 2=>array('pipe', 'w')), $pipes);
          fwrite($pipes[0], $input);fclose($pipes[0]);
          $stdout=stream_get_contents($pipes[1]);fclose($pipes[1]);
          $stderr=stream_get_contents($pipes[2]);fclose($pipes[2]);
          $rtn=proc_close($proc);
          return array('stdout'=>$stdout,
                       'stderr'=>$stderr,
                       'return'=>$rtn
                      );
         }
var_export(my_exec('echo -e $(</dev/stdin) | wc -l', 'h\nel\nlo'));

实例三

$cmd = "date";

   $output = system($cmd);
   printf("System Output: $output ");

   exec($cmd, $results);
   printf("Exec Output: {$results[0]} ");


php调用linux命令的权限问题


你可以使用定时任务执行你要调用的php,这时的权限就是root,
php通过函数system()调用系统命令


php一般是以apache用户身份去执行的,把apache加入到存储你文件的父文件夹属组里去,然后改该父文件夹权限为775,这样属组成员就有写的权限,而apache属于这个组就可以改写该目录下所有文件的权限,当然,属组最好不要是root,你可以为该文件夹改个其它普通用户组。

改apache/php的运行用户方法不安全
*/

 function read($filename,$filesze)
 {
  $fp=fopen($filename,"rb");//用fopen rb  属性读取文件并用flock lock_sh,lock_un来解锁
  if($fp)
  {
   flock($fp,LOCK_SH);
   clearstatcache();
   $filesize=filesize($filename);
   if($filesize>0)
   {
    $data=fread($fp,$filesize);
   }else
   {
    $data=false;
   }
   flock($fp,LOCK_UN);
   fclose($fp);
   return $data;
  }else
  {
   return false;
  }
 }
 
 /**
 *用fopen写入文件
 *@param string $filename
 *@param string $contents
 *@return boolean
 */
 
 function wirte($filename,&$contents)
 {
  $fp=fopen($filename,"wb");
  if($fp)
  {
   flock($fp,LOCK_EX);//同一时间锁定文件,只能一个人操作
   fwrite($fp,$contents);
   flock($fp,LOCK_UN);//保存数据握进行解锁文件并保存
   fclose($fp);
   return true;
  }else
  {
   return false;
  }
 }
 
//应用 1读文件,2写文件
$body ='';
if( $a = 1 )
{
 read('a.txt',1024);
}
else
{
 wirte('a.txt',$body);
}
//输出文件
echo $body;
?>

本款代码是一款简单的php留言板代码 ,就是把用户提交的数据保存到mysql数据库,判断进行验证用户是否为非法用户,非常简单的比较适合初学者。

 
<form name="form1" method="post" action="">
  <label>
  <input type="text" name="tp_nam">
  </label>
  <label>
  <input type="submit" name="Submit" value="提交">
  </label>
</form>
<?
//php mysql留言板代码  
$tp_time = $other->shortTime();
if ($_POST['tp_nam'] != "") {
//-------添加开始-------------
    $tp_name = $_POST['tp_nam'];
    $tp_contents = $_POST['message'];
    $at_id = $_POST['at_id'];
    if (!isset($_POST['chkkd'])) {
        exit();
    }

    if ($_POST['chkkd'] == $_SESSION['CodeNum']) {
        $_SESSION['CodeNum'] = '';
        $res = $tpEdit->tpInsert($tp_name, $tp_contents, $tp_time, $at_id, $col_id, 0, 0);
    } else {
        echo "<script> alert('验证码输入错误 ');window.location.href='www.111cn.net';</script>";
    }
//-----------添加结束-----------
    if ($res == 1) {
        echo "<script>alert('操作成功!');window.close();</script>";
        exit();
    } else {
        echo "<script>alert('请勿重复发帖,五分钟后再来!');window.close();</script>";
    }
}
?>

 

/*
js验证
<script type="text/javascript教程">
var dnum=document.getElementById("fenshu");
dnum.onkeyup = function(){
this.value=this.value.replace(/D/g,'');
if(dnum.value>1000||dnum.value<100){
         dnum.value=100;
}
}
</script>
*/

//php教程验证
$var=300;

$int_options = array(
"options"=>array
(
"min_range"=>0,
"max_range"=>256
)
);

if(!filter_var($var, FILTER_VALIDATE_INT, $int_options))
{
echo("Integer is not valid");
}
else
{
echo("Integer is valid");
}

//方法三js

var reg = /d{2,3}/;
var s = 888;
alert(reg.test(s));

//php正则

^([1-9][0-9][0-9]|1000)$

/*
这里我们主要是用到了正则表达式来完成,验证数字是否在指定的数据间距之间。
*/
?>

// 原是是根据用户输入的数字判断再转换成想要的大写数字,如果我们先把大小写存在一个数组,再判断进行转换就OK了。
$data = $_POST['rmb'];
if (!ereg("^[0-9.]",$data) ) die('请输入数值!');

$arr = array('零','壹','贰','叁','肆','伍','陆','柒','捌','玖');
$arr2 = array(0=>'',1=>'十',2=>'百',3=>'千',4=>'万',5=>'十',6=>'百',7=>'千',8=>'亿',9=>'十',10=>'百',11=>'千');

$len1 = strlen($int);//判断位数
$arrlen = array();
for($i=1;$i<=$len1;$i++){
$sublen = substr($int, $i-1,1); 
$arra['value'] = $sublen;
$arra['len'] = $len1 - $i+1;
array_push($arrlen, $arra);
}

for($j=0;$j<=$len1;$j++){
$va = $arrlen[$j]['value'];//RMB 数值
$valen = $arrlen[$j]['len'];//长度 确定单位
switch ($vc == $va)
{
  case 0: echo  $arr[0];break;case 1: echo  $arr[1];break;
  case 2: echo  $arr[2];break;case 3: echo  $arr[3];break;
  case 4: echo  $arr[4];break;case 5: echo  $arr[5];break;
  case 6: echo  $arr[6];break;case 7: echo  $arr[7];break;
  case 8: echo  $arr[8];break;case 9: echo  $arr[9];break;
                        
}

?>

<form id="form1" name="form1" method="post" action="">
  <input type="text" name="rmb" id="rmb" />
  <input type="submit" name="button" id="button" value="转换" />
</form>

标签:[!--infotagslink--]

您可能感兴趣的文章: