当前位置: 首页
编程语言
PHP5与PHP7中禁用eval函数的方法与安全考量

PHP5与PHP7中禁用eval函数的方法与安全考量

热心网友 时间:2026-05-07
转载

原文地址:https://blog.lmzg.org/2018/PHP_disable_eval.html

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

在PHP安全加固的讨论中,eval函数常常是焦点。这里有个关键点需要明确:eval是一个语言构造器而非普通函数,这意味着常规的disable_functions指令对它无效。这也就是为什么我们需要寻找其他途径来限制它。

市面上不少教程会提到使用suhosin扩展来禁用eval,这个方法在PHP5时代确实可行,但遗憾的是一般不适用于PHP7。当然,如果你执意尝试,可以寻找suhosin针对7.x版本的开发分支,但那意味着你需要面对潜在的稳定性风险。

如果你想了解传统的suhosin方法,可以参考这篇题为《LINUX服务器安全设置:禁止php的eval函数》的文章。而我们接下来要探讨的,是一个更通用、专门为禁用eval而生的扩展方案。

安装PHP开发包

第一步是安装PHP开发包,这为我们后续编译扩展提供必要环境。不同系统,命令略有不同。

对于Ubuntu或Debian系统,请注意区分你的PHP主版本:

# PHP5
sudo apt-get install php-dev
# PHP7
sudo apt-get install php7.0-dev

对于RedHat、CentOS或Fedora系统,命令则统一为:

yum install php-devel

下载PHP_diseval_extension

我们需要的主角是“PHP_diseval_extension”,这个扩展项目托管在GitHub上,地址是:PHP_diseval_extension

登录你的服务器,执行以下命令进行下载:

cd /tmp
git clone https://github.com/mk-j/PHP_diseval_extension.git

编译安装

下载完成后,进入源码目录,开始标准的编译安装流程:

cd /tmp/PHP_diseval_extension/source
phpize
./configure
make
sudo make install

如果编译过程顺利,你通常会看到类似下面的输出,这指明了扩展模块被安装到的具体目录:

Installing shared extensions: /usr/lib/php/20151012/

这个路径信息很重要,它确认了扩展已成功编译到系统。

启用扩展

扩展编译好了,接下来就是让它生效。这里提供两种常见的启用方式。

方法1:直接修改php.ini
这是最直接的方法。编辑你的php.ini配置文件,在任意位置添加一行:

extension=diseval.so

方法2:使用mods-a vailable目录(适用于Debian/Ubuntu系)
这种方式更便于管理多个PHP版本或SAPI。首先,在mods-a vailable目录下为扩展创建一个配置文件(注意,实际路径可能因PHP版本和安装方式而异):

vim /etc/php/7.0/mods-a vailable/diseval.ini

在该文件中写入同样内容:

extension=diseval.so

输入:wq保存并退出编辑器。

然后,创建一个软链接到PHP-FPM(或其他你使用的SAPI,如CLI)的配置目录,以启用该扩展:

ln -s /etc/php/7.0/mods-a vailable/diseval.ini /etc/php/7.0/fpm/conf.d/

无论采用哪种方法,最后一步都是重启PHP服务,使配置生效。对于使用PHP-FPM的情况,命令如下:

service php7.0-fpm restart

完成以上步骤后,eval函数就应该在相应的PHP环境中被成功禁用了。不妨用个简单的PHP脚本测试一下,看看是否还会执行。

来源:https://blog.csdn.net/hbh112233abc/article/details/86673974

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Java输出方法详解:控制台日志与文件写入全解析

Java输出方法详解:控制台日志与文件写入全解析

排查问题或了解运行环境时,使用System getProperty()方法可快速获取JVM和操作系统的关键信息。代码能输出Java版本、安装目录、类路径、操作系统详情及文件分隔符等属性。这些信息有助于排查类路径问题、判断环境兼容性、构建跨平台路径,并为日志调试提供重要上下文,是诊断环境问题的实用工具。

时间:2026-05-07 15:34
Ubuntu系统下使用Go语言实现机器学习的实践指南

Ubuntu系统下使用Go语言实现机器学习的实践指南

在Ubuntu上使用Go进行机器学习需先安装环境并配置工作空间,通过goget获取golearn等库。编写代码遵循数据加载、模型训练、预测评估的流程后运行程序。Go在性能与并发方面有优势,但生态不如Python丰富,更适合特定工程场景或统一技术栈的团队探索。

时间:2026-05-07 13:59
Ubuntu系统下Go语言程序打包方法与核心要点

Ubuntu系统下Go语言程序打包方法与核心要点

在Ubuntu中打包Go应用需关注环境配置、交叉编译与优化。通过GoModules管理依赖,使用CGO_ENABLED=0生成静态二进制文件以实现跨平台兼容。利用UPX和链接器参数减小体积,采用Docker多阶段构建制作最小镜像。交付时建议包含平台信息并签名,注意解决动态库依赖和版本锁定等常见问题。

时间:2026-05-07 13:58
Android开发中高效管理多个CheckBox组件的实用技巧

Android开发中高效管理多个CheckBox组件的实用技巧

在Android应用开发过程中,高效管理多个功能相似的复选框(CheckBox)是提升开发效率的关键。无论是应用设置界面、多选列表,还是动态生成的选项列表,如果对每个CheckBox都进行单独引用和操作,代码会迅速变得冗长且难以维护。那么,是否存在更优雅的解决方案?答案是肯定的——通过数组或动态集合

时间:2026-05-07 13:58
面向对象编程中封装字段如何提升代码安全性与维护性

面向对象编程中封装字段如何提升代码安全性与维护性

将类的公共字段改为私有,并提供公共的获取和设置方法,是提升代码安全性与可控性的基础重构。此举能防止外部随意读写,避免状态失控,并便于后续加入校验、脱敏等控制逻辑,适用于核心业务或敏感字段。

时间:2026-05-07 13:58
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程