20-3

PHP 代码审计流程

1. 宏观分析与项目理解

  • 项目概况了解: 首先,你需要快速浏览整个代码库,了解项目的规模、所使用的框架(例如 Laravel, ThinkPHP, WordPress 等)、版本以及主要功能模块。这有助于你构建一个大致的威胁模型
  • 寻找入口点: 确定程序的入口文件(如 index.php)和主要路由配置。这是所有用户输入和请求的起点,也是你后续深入分析的起点
  • 识别关键功能: 重点关注那些与用户交互、文件操作、数据库查询、命令执行以及身份认证相关的模块,这些地方最容易出现漏洞

2. 自动化工具扫描

  • 静态分析(SAST): 使用专门的静态代码分析工具对整个代码库进行扫描。这些工具可以快速地发现一些明显的、模式化的漏洞,例如 SQL 注入、XSS、命令注入等
    • 常用工具:
    • PHPStan: 检查代码中的潜在错误和不规范之处
    • SonarQube: 功能强大的代码质量管理平台,可以集成多种规则集
    • RIPS (付费) 或 php-security-scanner (开源): 专注于 PHP 安全漏洞扫描
  • 动态分析(DAST): 如果条件允许,在测试环境中部署代码,使用动态扫描工具(如 Burp Suite Pro, OWASP ZAP)模拟黑客行为进行测试。这可以发现那些只有在运行时才能触发的漏洞