首页 > 后端开发 > 正文

FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败

2025-01-02 08:03:53 | 我爱编程网

今天我爱编程网小编为大家带来了FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败,希望能帮助到大家,一起来看看吧!

本文目录一览:

FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败

FileSystemPHP Filesystem 函数

以下是改写后的文章内容,以HTML标签片段形式呈现:

PHP自早期版本开始就支持一系列文件系统操作函数,以下是其中一些关键函数的简介:



  • basename() : 返回路径中的文件名部分。

  • chgrp() : 改变文件组权限。

  • chmod() : 修改文件的访问权限模式。

  • chown() : 更改文件的所有者。

  • clearstatcache() : 清除文件状态缓存。

  • copy() : 复制文件。

  • delete() : 通常使用 unlink() 或 unset() 删除文件。

  • dirname() : 获取路径中的目录名称部分。

  • disk_free_space() : 返回指定目录的可用空间。

  • disk_total_space() : 提供目录的磁盘总容量。

  • fclose() : 关闭打开的文件。

  • feof() : 检查文件指针是否到达文件结束位置。

  • fflush() : 清空输出缓冲区的内容。

  • fgetc() : 从文件中读取一个字符。

  • fgetcsv(), fgets(), fgetss() : 分别用于解析CSV、读取一行和过滤HTML/PHP标签。

  • file() : 将整个文件读入数组。

  • file_exists() : 检查文件或目录是否存在。

  • file_get_contents() : 读取文件内容到字符串。

  • file_put_contents() : 将字符串写入文件。

  • fileatime(), filectime(), filemtime(), fileowner(), fileperms(), filesize(), filetype() : 提供文件的各种时间戳和属性信息。

  • flock() : 锁定或释放文件。

  • fnmatch() : 根据模式匹配文件名或字符串。

  • fopen() : 打开文件或URL。

  • fpassthru() : 读取文件内容并输出缓冲。

  • fputcsv() : 将CSV格式的数据写入文件。

  • fputs(), fwrite() : 写入文件的别名。

  • fread() : 读取文件内容。

  • fscanf() : 根据指定格式解析输入数据。

  • fseek() : 在文件中定位。

  • fstat() : 获取文件状态信息。

  • ftell() : 返回文件指针位置。

  • ftruncate() : 调整文件长度到指定长度。

  • fwrite() : 向文件写入数据。

  • glob() : 匹配文件名模式并返回数组。

  • is_dir(), is_executable(), is_file(), is_link(), is_readable(), is_uploaded_file(), is_writable(), is_writeable() : 分别检查文件类型、可执行性、文件类型、符号链接、可读性、上传文件状态、可写性等。

  • link(), linkinfo(), lstat(), mkdir(), move_uploaded_file(), parse_ini_file(), pathinfo(), pclose(), popen(), readfile(), readlink(), realpath(), rename(), rewind(), rmdir(), set_file_buffer(), stat(), symlink(), tempnam(), tmpfile(), touch(), umask(), unlink() : 用于创建链接、获取链接信息、获取符号链接信息、创建目录、移动上传文件、解析ini文件、获取路径信息、操作进程、读取文件、获取链接目标、获取绝对路径、重命名文件、倒回文件指针、删除目录、设置文件缓冲、获取文件信息、创建符号链接、创建临时文件、设置文件时间戳和权限、删除文件等。

FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败

菜鸟求助:PHP中调用系统命令为何有些命令总是失败

PHP执行系统命令(简介及方法)
在PHP中调用外部命令,可以用如下三种方法来实现:
方法一:用PHP提供的专门函数(四个):
PHP提供4个专门的执行外部命令的函数:exec(), system(), passthru(), shell_exec()
1)exec()
原型: string exec ( string $command [, array &$output [, int &$return_var ]] )
说明: exec执行系统外部命令时不会输出结果,而是返回结果的最后一行。如果想得到结果,可以使用第二个参数,让其输出到指定的数组。此数组一个记录代表输出的一行。即如果输出结果有20行,则这个数组就有20条记录,所以如果需要反复输出调用不同系统外部命令的结果,最好在输出每一条系统外部命令结果时清空这个数组unset($output),以防混乱。第三个参数用来取得命令执行的状态码,通常执行成功都是返回0。
<?php
exec("dir",$output);
print_r($output);
?>
2)system()
原型: string system ( string $command [, int &$return_var ] )
说明: system和exec的区别在于,system在执行系统外部命令时,直接将结果输出到游览器,如果执行命令成功则返回true,否则返回false。第二个参数与exec第三个参数含义一样。
<?php
system("pwd");
?>
3)passthru()
原型: void passthru ( string $command [, int &$return_var ] )
说明: passthru与system的区别,passthru直接将结果输出到游览器,不返回任何值,且其可以输出二进制,比如图像数据。第二个参数可选,是状态码。
<?php
header("Content-type:image/gif");
passthru("/usr/bin/ppm2tiff /usr/share/tk8.4/demos/images/teapot.ppm");
?>
4)shell_exec()
原型: string shell_exec ( string $cmd )
说明: 直接执行命令$cmd
<?php
$output = shell_exec('ls -lart');
echo "<pre>$output</pre>";
?>
方法二:反撇号
原型: 反撇号`(和~在同一个键)执行系统外部命令
说明: 在使用这种方法执行系统外部命令时,要确保shell_exec函数可用,否则是无法使用这种反撇号执行系统外部命令的。
<?php
echo `dir`;
?>
方法三:用popen()函数打开进程
原型: resource popen ( string $command , string $mode )
说明: 能够和命令进行交互。之前介绍的方法只能简单地执行命令,却不能与命令交互。有时须向命令输入一些东西,如在增加系统用户时,要调用su来把当前用户换到root用户,而su命令必须要在命令行上输入root的密码。这种情况下,用之前提到的方法显然是不行的。
popen( )函数打开一个进程管道来执行给定的命令,返回一个文件句柄,可以对它读和写。返回值和fopen()函数一样,返回一个文件指针。除非使用的是单一的模式打开(读or写),否则必须使用pclose()函数关闭。该指针可以被fgets(),fgetss(),fwrite()调用。出错时,返回FALSE。
<?php
error_reporting(E_ALL);
/* Add redirection so we can get stderr. */
$handle = popen('/path/to/executable 2>&1', 'r');
echo "'$handle'; " . gettype($handle) . "\n";
$read = fread($handle, 2096);
echo $read;
pclose($handle);
?>
要考虑两个问题:安全性和超时
1)安全性
由于PHP基本是用于WEB程序开发的,所以安全性成了人们考虑的一个重要方面 。于是PHP的设计者们给PHP加了一个门:安全模式。如果运行在安全模式下,那么PHP脚本中将受 到如下四个方面的限制:
执行外部命令
在打开文件时有些限制
连接MySQL数据库
基于HTTP的认证
在安全模式下,只有在特定目录中的外部程序才可以被执行,对其它程序的调用将被拒绝。这个目录可以在PhP.ini 文件中用safe_mode_exec_dir指令,或在编译PHP是加上--with-exec-dir选项来指定。
当你使用这些函数来执行系统命令时,可以使用escapeshellcmd()和escapeshellarg()函数阻止用户恶意在系统上执行命令,escapeshellcmd()针对的是执行的系统命令,而escapeshellarg()针对的是执行系统命令的参数。这两个参数有点类似addslashes()的功能。
2)超时
当执行命令的返回结果非常庞大时,可以需要考虑将返回结果输出至其他文件,再另行读取文件,这样可以显著提高程序执行的效率。
如果要执行的命令要花费很长的时间,那么应该把这个命令放到系统的后台去运行。但在默认情况下,象system()等函数要等到这个命令运行完才返回(实际上是在等命令的输出结果),这肯定会引起PHP脚本的超时。解决的办法是把命令的输出重定向到另外一个文件或流中,如:
<?php
system("/usr/local/bin/order_proc > /tmp/abc ");
?>
但我调用的DOS命令需要几分钟的时间,而且为了批处理不能简单的把结果写入文件了事,要顺序执行以下的程序
PHP设置了调用系统命令的时间限制,如果调用命令超时,虽然这个命令还是会被执行完,但PHP没有得到返回值,被终止了(最可恨的是,不显示任何错误)
修改php.ini并重启Apache以允许系统命令运行更长的时间
max_execution_time = 600
我的程序是后台运行的,逻辑OK就成了

fgetss语法

我爱编程网(https://www.52biancheng.com)小编还为大家带来fgetss语法的相关内容。

在PHP中,fgetss()函数是一个用于从指定文件中读取字符串的内置函数,其语法如下: 我爱编程网


php
string fgetss(file resource, [length = 1024], [tags = NULL])


其中:



  • file : 这个参数是必需的,它指定了要读取的文件资源。在PHP中,通常通过 fopen() 函数打开文件并返回一个文件资源。

  • length : 这是一个可选参数,用于规定要读取的字节数。默认值是1024字节,但在PHP 5之前的版本中,这个参数是必需的,必须明确指定。

  • tags : 也是一个可选参数,用于规定将被删除的HTML标签。在某些情况下,可能需要从HTML文本中提取纯文本内容,这时可以设置这个参数来过滤掉指定的标签。


例如,如果你想要从一个文件中读取指定长度的文本,同时删除所有HTML标签,你可以这样做:


php
$file = fopen('example.txt', 'r');
$content = fgetss($file, 512, '||
|

');
fclose($file);
echo $content;


这里,fgetss()函数会读取最多512字节的内容,并移除所有包含在尖括号``、``和`
`中的标签。

以上就是我爱编程网整理的FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败相关内容,想要了解更多信息,敬请查阅我爱编程网。更多相关文章关注我爱编程网:www.52biancheng.com

免责声明:文章内容来自网络,如有侵权请及时联系删除。
标签: PHP
与“FileSystemPHP Filesystem 函数 菜鸟求助:PHP中调用系统命令为何有些命令总是失败”相关推荐