- 1 信息安全简介
- 1.1 信息安全发展史
- 1.2 信息安全等级保护
- 2 安全 OS
- 2.1 UNIX 系统安全
- 2.1.1 设置健壮的密码
- 2.1.2 删除所有的特殊账户
- 2.1.3 关闭不需要的服务
- 2.1.4 远程登陆管理
- 2.1.5 限制 IP 访问
- 2.1.6 日志监控
- 2.2 Linux 系统安全
- Linux 安全设置手册
- Linux 服务器安全加固
- Linux 防火墙
- SELinux
- SSH 免密登陆
- 2.3 Windows 系统安全
- Windows 常见安全隐患
- 防火墙-Microsoft Defender
- 本章参考
- 3 访问控制技术
- 3.1 基于角色的访问控制 RBAC
- 基于 RBAC 的延展-用户组(租户)
- 示例 1:Python Django 后台管理
- 示例 2:Python flask_appbuilder 后台管理
- 3.2 认证
- 3.2.1 认证机制
- 3.2.2 OpenID
- 3.2.3 LDAP
- 3.2.4 Kerberos
- 3.2.5 数字签名
- 3.2.6 基于证书的认证
- 3.3 授权
- 3.3.1 OAuth
- 3.4 HTTPS
- 3.4.1 HTTPS 原理
- 3.4.2 证书
- 3.4.3 自签名证书
- 本节参考
- 案例
- 天网 MAZE 的信用卡机制
- S3 认证机制
- 云盘认证机制
- 双因子认证
- 扫码登陆
- 单点登陆 SSO
- 本章参考
- 4 安全编程
- 4.1 内存管理
- 4.2 安全编程实践
- 4.2.1 使用断言进行防止错误
- 4.3 语言相关的安全编码
- 4.3.1 net 中使用安全函数
- 4.3.2 PHP 代码执行漏洞
- 4.4 源码保护
- Java 源码保护
- python 源码保护
- 本章参考
- 5 安全算法
- 6 安全架构
- 云安全
- 云安全事件案例
- 云计算带来的安全挑战
- 应用:安全云/云查杀
- 业界案例
- 华为的安全白皮书
- 参考资料
- 附录
- 安全相关法律法规
- 个人信息安全
- 云安全标准与组织
- 国际
- 国内
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
4.3.2 PHP 代码执行漏洞
代码执行函数
PHP 中可以执行代码的函数。如 eval()、assert()、system()、exec()、shell_exec()、passthru()、 escapeshellcmd()、pcntl_exec() 等
文件包含代码注射
文件包含函数在特定条件下的代码注射,如 include()
、 include_once()
、 require()
、 require_once()
。
当 allow_url_include=On
,PHP Version>=5.2.0 时,导致代码注射。
include.php
<?php
include($_GET[‘a’]);
?>
URL: http://localhost/test/include.php?a=data:text/plain,%3C?php%20phpinfo();?%3E
正则匹配代码注射
众所周知的 preg_replace()
函数导致的代码注射。当 pattern 中存在/e 模式修饰符,即允许执行代码。这里我们分三种情况讨论下
1 ). preg_replace()
pattern 参数注射
pattern 即第一个参数的代码注射。
当 magic_quotes_gpc=Off
时,导致代码执行。
demo code 3.1: preg_replace1.php
<?php
echo $regexp = $_GET[‘reg’];
$var = ‘<php>phpinfo()</php>’;
preg_replace(`/<php>(.*?)$regexp`, ‘\1’, $var);
?>
URL: preg_replace1.php?reg=%3C/php%3E/e
2 ). preg_replace()
replacement 参数注射
replacement 即第二个参数的代码注射,导致代码执行。
3 ). preg_replace()
第三个参数注射
我们通过构造 subject 参数执行代码。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论