最近在做php和linux crontab的联调,发现php在linux下的权限问题需要引起注意,调试问题的过程中发现有许多问题前人说的比较零散,我在这里汇总,顺带抛砖引玉一下。

1、$result=system($cmd,$return_status)需要区分返回值与返回状态。返回值是$cmd执行后返回执行结果的最后一行,而$return_status是返回状态,比如$cmd是crontab一个计划任务,若Linux执行成功,则返回0(详见Linux条件测试)给$return_status,故在PHP端看到$return_status变为0;若执行的是ls,则PHP端看$return_status是一串字符(很可能是乱码)。

2、路径所涉及的权限问题会导致system()看起来无效(命令执行后Linux没反应),其实主要观察返回状态即可,如system($cmd,$return_status),$return_status返回状态这里要小心,因为它是来自linux的消息,返回了0代表执行成功,1代表执行失败。所以,PHP配合linux时,涉及到路径的都应该仔细考虑一下是否有权限,特别是返回状态为1的时候。

3、往某目录A下增删文件,只要目录A有w权限,相应的用户就能增删,比如PHP在linux看来属于其他用户(www-data这个用户组),若将目录A的其他用户w权限关闭,则无法在该目录下创建文件,可以通过sudo,但是一定要保证PHP有使用sudo的权限(见第4条),否则也是无法创建的。而且能否往A中写只与A的权限有关,与A的父目录B有无w权限无直接关系。顺带提醒一下,php调用linux命令创建文件时,文件名应该转义,如 $cmd='touch /home/pi/`date +\%m_\%d_\%H_\%M.txt`'; system($cmd);  否则会遇到一切看起来都正常,但是就是没文件被创建的问题,因为不转义,Linux无法识别文件名中的符号。

4、PHP调用Linux命令是以www-data这个用户组身份进行的,这个用户组的默认权限特别低,以至于用system()涉及sudo等需要密码的命令都无法执行。解决方法可以命令行输入sudo visudo打开sudoers.tmp,在这里面添加“www-data ALL=(ALL) NOPASSWD: ALL”(或者在/etc/sudoers.d/下新建一个660权限的文件,并添加此句命令,虽然系统会自动把权限改回440,为了方便写入,这里还是新建一个660的文件),这样www-data这个用户组(即PHP)执行Linux的sudo命令就没有问题了。

5、所有正在运行crontab计划的用户在/var/spool/cron/crontabs目录下可以看到(目录名大同小异吧,都是在/var/spool/cron/下)。命令行中直接crontab的话,是添加root的任务计划,需要su后crontab -l才能看到;直接crontab -l看到只是当前用户的计划任务。crontab -u -user 可以指定某个用户的任务计划,当php取得sudo权限后,就可以为linux下其他用户定制crontab了。

小结:php和linux联调,我发现遇到的问题主要是权限,所以不能实现功能时,先检查权限是否得到满足,比如php的www-data处于何种权限,要写入的目录处于何种权限等;当权限疏导好后,用system()执行linux命令还是很方便的。

原创博客,如有错误,欢迎指正。

php通过system()调用Linux命令问题的更多相关文章

  1. scala调用Linux命令行

    在 scala 里面存在 调用 Linux 命令行的函数: import scala.sys.process._ 执行的方法也不难: import scala.sys.process._ /** * ...

  2. Spark调用Linux命令实现解压和压缩功能

    一.应用场景 在Spark程序中调用Linux命令,实现一些程序难以实现的功能,例如:发送模拟邮件.文件打包或解压等等 二.代码实现 package big.data.analyse.linux im ...

  3. Java调用Linux命令执行

    调用方式 Java调用linux命令执行的方式有两种,一种是直接调用linux命令,一种是将linux命令写到.sh脚本中,然后调用脚本执行. 详细说明 直接调用:使用java中lang包下面的Run ...

  4. Java调用Linux命令(cd的处理)

    一.Java调用Linux系统的命令非常简单 这是一个非常常用的调用方法示例: public String executeLinuxCmd(String cmd) { System.out.print ...

  5. java调用Linux命令报错:java.io.IOException: Cannot run program "ps": CreateProcess error=2, ?????????

    在idea里面,java代码:Runtime.getRuntime().exec("ps -aux") 是因为默认是用windows平台运行了,所以报错,得改成调用Linux平台运 ...

  6. 如何在java程序中调用linux命令或者shell脚本

    转自:http://blog.sina.com.cn/s/blog_6433391301019bpn.html 在java程序中如何调用linux的命令?如何调用shell脚本呢? 这里不得不提到ja ...

  7. java程序中调用Linux命令Windows命令

    目前总结的方法: 调用Linux简单的命令行,设置文件夹权限755 String scriptDir = "/home/wenf"; String cmd = "chmo ...

  8. jsch ssh服务器调用Linux命令或脚本的小问题

    代码如下: public static boolean execshell(String command, String user, String passwd, String host) throw ...

  9. Python中如何调用Linux命令

    一.使用os模块 In [1]: import os #导入os模块 In [2]: os.system('ls') anaconda-ks.cfg epel-release-7-5.noarch.r ...

随机推荐

  1. 转载--Typecho install.php 反序列化导致任意代码执行

    转载--Typecho install.php 反序列化导致任意代码执行 原文链接(http://p0sec.net/index.php/archives/114/) 0x00 前言 漏洞公布已经过去 ...

  2. Fedora 23建立wifi热点(Android手机可用)

    在ubuntu14.04下使用ap-hotspot,速度还不错.但是在15.04下就用不了了,不知为啥.现在使用fedora23,在学校还是挺需要给手机连wifi的,于是google看看ap-hots ...

  3. 深入浅出多线程——ReentrantLock (一)

    ReentrantLock是一个排它重入锁,与synchronized关键字语意类似,但比其功能更为强大.该类位于java.util.concurrent.locks包下,是Lock接口的实现类.基本 ...

  4. Android破解学习之路(一)——简单的登录破解

    最近突然心血如潮开始学了Android破解,初入门,便是将经验记录下来. 准备工作: 1.一个登录简单APP 在我们破解之前,我们需要做一个简单的登录APP,输入相应的账号与密码便是弹出登录成功的对话 ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(88)-Excel导入和导出-主从表结构导出

    前言 前面一篇详细讲解了导入导出,本节演示混合结构的导出功能!同时提供代码下载.. 代码下载 vs2015+无数据库 先看效果图:这个一个混合的Excel,列表与自定义信息的混合! 我们的步骤大概分为 ...

  6. PHP 字符串转 bigint 型md5

    1 2 3 4 5 6 7 8 /**      * 字符串转bigint      * @return bigint(string)      */     public function md5( ...

  7. 41.Linux应用调试-修改内核来打印用户态的oops

    1.在之前第36章里,我们学习了通过驱动的oops定位错误代码行 第36章的oops代码如下所示: Unable to handle kernel paging request at //无法处理内核 ...

  8. eclipse中Cannot change version of project facet Dynamic Web Module to 2.5.

    Cannot change version of project facet Dynamic Web Module to 2.5.这个错误可能很多人都碰到过,这里网上查了一些资料,解决的问题.所以这里 ...

  9. java web 学习笔记 jsp内置对象

    jsp2 表达式语言的内置对象 使用方式${object.attributename} 或者${object["attributename"]} pageContext pageS ...

  10. TRITON恶意软件简单分析与防护方案

    一.攻击简介 2017年12月,安全研究人员发现了一款针对工控系统安全仪表系统(SIS)的恶意软件"TRITON",该软件以施耐德电气Triconex安全仪表控制系统为目标展开攻击 ...