资讯专栏INFORMATION COLUMN

PHP高级语法总结

Hydrogen / 985人阅读

摘要:一执行系统外部命令输出并返回最后一行结果。相同点都可以获得命令执行的状态码用提供的专门函数提供共了个专门的执行外部命令的函数,,。第二个参数是可选的,用来得到命令执行后的状态码。

php高级语法总结。

一、执行系统外部命令

system() 输出并返回最后一行shell结果。

exec() 不输出结果,返回最后一行shell结果,所有结果可以保存到一个返回的数组里面。

passthru() 只调用命令,把命令的运行结果原样地直接输出到标准输出设备上。

相同点:都可以获得命令执行的状态码

1)用PHP提供的专门函数

PHP提供共了3个专门的执行外部命令的函数:system(),exec(),passthru()

system()
原型:string system (string command [, int return_var])
system()函数很其它语言中的差不多,它执行给定的命令,输出和返回结果。第二个参数是可选的,用来得到命令执行后的状态码。
例子:
复制代码 代码如下:

 

exec()
原型:string exec (string command [, string array [, int return_var]])
exec ()函数与system()类似,也执行给定的命令,但不输出结果,而是返回结果的最后一行。虽然它只返回命令结果的最后一行,但用第二个参数array 可以得到完整的结果,方法是把结果逐行追加到array的结尾处。所以如果array不是空的,在调用之前最好用unset()最它清掉。只有指定了第二 个参数时,才可以用第三个参数,用来取得命令执行的状态码。

 

我们可以exec()这个方法获取服务器端的IP

// 注意:ipconfig是Windows下的查看命令,而Linux为ifconfig命令
exec("ifconfig -a", $arr);
print_r($arr);

passthru()
原型:void passthru (string command [, int return_var])
passthru ()只调用命令,不返回任何结果,但把命令的运行结果原样地直接输出到标准输出设备上。所以passthru()函数经常用来调用象pbmplus (Unix下的一个处理图片的工具,输出二进制的原始图片的流)这样的程序。同样它也可以得到命令执行的状态码。
例子:
复制代码 代码如下:

 
2) 用popen()函数打开进程

上面的方法只能简单地执行命令,却不能与命令交互。但有些时候必须向命令输入一些东西,如在增加Linux的系统用户时,要调用su来把当前用户换到root才行,而su命令必须要在命令行上输入root的密码。这种情况下,用上面提到的方法显然是不行的。

popen ()函数打开一个进程管道来执行给定的命令,返回一个文件句柄。既然返回的是一个文件句柄,那么就可以对它读和写了。在PHP3中,对这种句柄只能做单一 的操作模式,要么写,要么读;从PHP4开始,可以同时读和写了。除非这个句柄是以一种模式(读或写)打开的,否则必须调用pclose()函数来关闭 它。
例子1:
复制代码 代码如下:

 

示例2:

 
3)系统命令实际项目中应用示例
//查找到php安装位置
$phpcmd = exec("which php");
print_r($phpcmd);
// 输出结果  /usr/bin/php   

$arr = array();
$ret = exec("/bin/ls -l", $arr); 
print_r($ret);
print_r($arr);
4)使用外部命令需要注意的安全性

比如,你有一家小型的网上商店,所以可以出售的产品列表放在一个文件中。你编写了一个有表单的HTML文件,让你的用户输入他们的EMAIL地 址,然后把这个产品列表发给他们。假设你没有使用PHP的mail()函数(或者从未听说过),你就调用Linux/Unix系统的mail程序来发送这 个文件。程序就象这样:
复制代码 代码如下:

 

用这段代码,一般的用户不会产生什么危险,但实际上存在着非常大的安全漏洞。如果有个恶意的用户输入了这样一个EMAIL地址:

"--bla ; mail someone@domain.com < /etc/passwd ;" 

那么这条命令最终变成:

"mail --bla ; mail someone@domain.com < /etc/passwd ; < products.txt" 

我相信,无论哪个网络管理人员见到这样的命令,都会吓出一身冷汗来。
幸 好,PHP为我们提供了两个函数:EscapeShellCmd()EscapeShellArg()。函数EscapeShellCmd把一个字符串 中所有可能瞒过Shell而去执行另外一个命令的字符转义。这些字符在Shell中是有特殊含义的,象分号(),重定向(>)和从文件读入 (<)等。函数EscapeShellArg是用来处理命令的参数的。它在给定的字符串两边加上单引号,并把字符串中的单引号转义,这样这个字符串 就可以安全地作为命令的参数。
再来看看超时问题。如果要执行的命令要花费很长的时间,那么应该把这个命令放到系统的后台去运 行。但在默认情况下,象system()等函数要等到这个命令运行完才返回(实际上是要等命令的输出结果),这肯定会引起PHP脚本的超时。解决的办法是 把命令的输出重定向到另外一个文件或流中,如:
复制代码 代码如下:

 /tmp/null &"); 
?> 
5)、高级命令实际项目中应用:

自己实现异步执行任务的队列(二)

do_queue.php部分代码:

$phpcmd = exec("which php");    //查找到php安装位置
$cqueue = new Queue();
$tasks = $cqueue->getQueueTask(200);
foreach ($tasks as $t)
{
    $taskphp = $t["taskphp"];
    $param = $t["param"];
    $job = $phpcmd . " " . escapeshellarg($taskphp) . " " . escapeshellarg($param);
    system($job);
}
二、图片处理 1) 取得图像大小

array getimagesize ( string $filename [, array &$imageinfo ] )
getimagesize() 函数将测定任何 GIF,JPG,PNG,SWF,SWC,PSD,TIFF,BMP,IFF,JP2,JPX,JB2,JPC,XBM 或 WBMP 图像文件的大小并返回图像的尺寸以及文件类型和一个可以用于普通 HTML 文件中 IMG 标记中的 height/width 文本字符串。

如果不能访问 filename 指定的图像或者其不是有效的图像,getimagesize() 将返回 FALSE 并产生一条 E_WARNING 级的错误。

getimagesize()官方文档说明。

示例,获取图片大小:

$url = "http://img2.fengniao.com/product/157/367/ce0Ar9cBeSl2A.jpg";
$ret = getimagesize($url);
var_dump($ret);

打印结果:

Array
(
    [0] => 2100
    [1] => 1280
    [2] => 2
    [3] => width="2100" height="1280"
    [bits] => 8
    [channels] => 3
    [mime] => image/jpeg
)
三、事务处理
 //用户修改密码
    public function modfy_password($user_password_old, $user_password_confirm, $user_name)
    {
        $state = 0;
        if($user_password_old && $user_password_confirm && $user_name)
        {
            $password_old     = strval(md5($user_password_old));
            $password_confirm = strval(md5($user_password_confirm));
            $user_id = $GLOBALS["db"]->getOne("select user_id from admin_user where user_name="$user_name" and password="$password_old"");
            if($user_id)
            {
                /*
                $state = $GLOBALS["db"]->query("update admin_user set password="$password_confirm" where user_id=$user_id");
                if($state == true)
                {
                    // 这里需要做回滚,如果ldap密码更新失败,则上边的操作也不允许密码修改。【20170726】
                    $ret = $this->modify_ldap_pwd($user_name, $user_password_old, $user_password_confirm);
                    $state = 1; //用户密码修改成功
                }
                */

                // 添加事物处理
                try {
                    // 开启事物
                    $GLOBALS["db"]->beginTransaction();

                    // 更新管理平台密码
                    $state = $GLOBALS["db"]->query("update admin_user set password="$password_confirm" where user_id=$user_id");
                    if($state != true)
                    {
                        throw new Exception ("更新管理平台密码失败!");
                    }

                    $ret = $this->modify_ldap_pwd($user_name, $user_password_old, $user_password_confirm);
                    if(!$ret)
                    {
                        throw new Exception ("更新LDAP密码失败!");
                    }

                    // 提交事物
                    $GLOBALS["db"]->commit();
                    $state = 1;
                }
                catch (Exception $e)
                {
                    // 回滚
                    $GLOBALS["db"]->rollBack();
                }
            }
            else
            {
                $state = -1; //用户的原始密码不正确
            }
        }

        return $state;
    }

相关文章:
PHP 执行系统外部命令 system() exec() passthru()
PHP中exec与system用法区别

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/22372.html

相关文章

  • SegmentFault 技术周刊 Vol.40 - 2018,来学习一门新的编程语言吧!

    摘要:入门,第一个这是一门很新的语言,年前后正式公布,算起来是比较年轻的编程语言了,更重要的是它是面向程序员的函数式编程语言,它的代码运行在之上。它通过编辑类工具,带来了先进的编辑体验,增强了语言服务。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不觉已经到来了,总结过去的 2017,相信小伙们一定有很多收获...

    caspar 评论0 收藏0
  • SegmentFault 技术周刊 Vol.40 - 2018,来学习一门新的编程语言吧!

    摘要:入门,第一个这是一门很新的语言,年前后正式公布,算起来是比较年轻的编程语言了,更重要的是它是面向程序员的函数式编程语言,它的代码运行在之上。它通过编辑类工具,带来了先进的编辑体验,增强了语言服务。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不觉已经到来了,总结过去的 2017,相信小伙们一定有很多收获...

    nihao 评论0 收藏0
  • SegmentFault 技术周刊 Vol.40 - 2018,来学习一门新的编程语言吧!

    摘要:入门,第一个这是一门很新的语言,年前后正式公布,算起来是比较年轻的编程语言了,更重要的是它是面向程序员的函数式编程语言,它的代码运行在之上。它通过编辑类工具,带来了先进的编辑体验,增强了语言服务。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不觉已经到来了,总结过去的 2017,相信小伙们一定有很多收获...

    Drummor 评论0 收藏0
  • 高级PHP工程师应该具备的一些技能

    摘要:很多面试,很多人员能力要求都有高级工程师的字眼,如果您真心喜欢,并且您刚起步,那么我简单说说一个高级工程师所应该具备的,希望给初级或已经达到中级的工程师一些帮助。程序的执行顺序问题。 初次接触PHP,就为其美所折服,于是一发不可收拾。 很多面试,很多人员能力要求都有PHP高级工程师的字眼,如果您真心喜欢PHP,并且您刚起步,那么我简单说说一个PHP高级工程师所应该具备的,希望给初级或已...

    Lsnsh 评论0 收藏0
  • 如何让PHP性能问题不再饱受诟病

    摘要:作为开发中应用最广泛的开源脚本语言,凭借库类丰富,使用简单,安全等特点,成为和等互联网巨头和全球超过网站的主要开发语言,然而性能问题是一直以来饱受诟病的,来自开发组的高驰涛同学将为我们带来他对性能优化方面的思考和建议。 PHP作为Web开发中应用最广泛的开源脚本语言,凭借库类丰富,使用简单,安全等特点,成为Facebook和BAT等互联网巨头和全球超过70%网站的主要开发语言,然而性能...

    warnerwu 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<