怎么禁止php获取linux服务器所有文件?

怎么禁止php获取linux服务器所有文件?,第1张

httpd进程是root身租滚份吧,这样很危险,一般的办法是轮型弯设置httpd的进程身份为apache、www或者nobody这样普通用户,如果是APACHE,可腊闷以在httpd.conf里面如下设置:

user = apache

group = apache

当然,需要建立对应的用户,否则无法启动。

首先先要给大家介绍PHP执行linux系统命令的几个基本函数。

system函数

说明:执行外部程序并显示输出资料。

语法:string system(string command, int [return_var])

返回值: 字符串

详细介绍:

本函数就像是 C 语中的函数 system(),用来执行指令,并输出结果。若是 return_var 参数存在,则执行 command 之后的状态会填入 return_var 中。同样值得注意的是若需要处理用户输入的资料,而又要防止用户耍花招破解系统,则可以使用 EscapeShellCmd()。若 PHP 以模块式的执行,本函数会在每一行输出后自动更新 Web 服务器的输出缓冲暂存区。若需要完整的返回字符串,且不想经过不必要的其它中间的输出界面,可以使用 PassThru()。

实例代码:启枝告

<?php

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

echo 'Last line of the output: ' . $last_line

echo '<hr/>Return value: ' . $retval

?> 

exec函数

说明:执行外部程序。

语法:string exec(string command, string [array], int [return_var])

返回值: 字符串

详细介绍:

本函数执行输入 command 的外部程序悄明或外部指令。它的返回字符串只是外部程序执行后返回的最后一行;若需要完整的返回字符串,可以使用 PassThru() 这个函数。

要是参数 array 存在,command 会将 array 加到参数中执行,若不欲 array 被处理,可以在执行 exec() 之前呼叫 unset()。若是 return_var 跟 array 二个参数都存在,则执行 command 之后的状态会填入 return_var 中。

值得注意的是若需要处理使用者输入的资料,而又要防止使用者耍花招破解系统,则可以使用 EscapeShellCmd()。

实例代码:

<?php

echo exec('whoami')

?> 

popen函数

说明:打开文件

语法:int popen(string command, string mode)

返回值: 整数

详细介绍:

本函数执行指令开档,而该文件是用管道方式处理的文件。用本函数打开的文件只能是单向的 (只能读或只能写),而且一定要用 pclose() 关闭。在文件 *** 作上可使用 fgets()、fgetss() 与 fputs()。搭迟若是开档发生错误,返回 false 值。

实例代码:

<?

$fp = popen( "/bin/ls", "r" )

?> 

通过上述函数,PHP可以执行linux系统的shell命令。

在命令行运行的话,linux和Windows环境下一样,如果你的PHP已经设置为全局的,可以芹庆直接

php 后跟文件名,如果不是全局的就埋烂进入php安装bin目录下,就是有嫌液握php.exe文件那个目录下执行 php+文件名。学习Linux的话可参考《Linux就该这么学》。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/12283537.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存