chmod修改后权限不生效的主因是PHP进程用户(如www-data)无对应权限、父目录缺x执行权、SELinux拦截;需用sudo -u www-data验证,并配合chown设正确属组与权限。
Linux 系统中 chmod 命令执行成功,但 PHP 仍报“Permission denied”或无法读写文件,通常不是命令没运行,而是权限作用对象错了。最常踩的坑是:PHP 进程实际以 www-data(Debian/Ubuntu)或 apache(CentOS/RHEL)用户身份运行,而你用 root 或自己的账号改了权限,却没覆盖到该用户所需的访问能力。
另一个高频原因是:目录缺少执行(x)权限。PHP 要进入一个目录读取其中文件,该目录必须对运行用户有 x 权限;仅 r 不够。比如

/var/www/html/uploads 目录若权限是 644,PHP 就进不去——得设成 755(目录)+ 644(文件)才合理。
别只盯着文件本身。PHP 的权限检查分三层,缺一不可:
config.php)对 PHP 进程用户有读/写权限/var/www/html/ → /var/www/ → /var/)都需有 x 权限,否则路径无法遍历fopen('php://input') 或临时文件(如 upload_tmp_dir),还要确认 PHP 配置里 sys_temp_dir 或 upload_tmp_dir 指向的目录可写且属主正确改完权限别直接 reload PHP,先验证是否真生效:
ps aux | grep php 或 ps aux | grep apache 确认当前 Web 服务进程的运行用户(如 www-data)sudo -u www-data ls -l /path/to/your/file —— 看是否能列出来、能否 cat
getenforce 若返回 Enforcing,则即使 chmod 正确,SELinux 也可能拦截。临时关掉测试:sudo setenforce 0;长期方案是用 chcon 或 semanage fcontext 调整上下文opcache.revalidate_freq 默认 2 秒,若刚改完文件内容就刷新页面,可能看到旧逻辑——这不是权限问题,别混为一谈单纯 chmod 777 是危险且无效的捷径。真实生产环境应:
sudo chown :www-data /path/to/dir
755(drwxr-xr-x),文件为 644(-rw-r--r--)cache/、uploads/)单独加 g+w:sudo chmod 775 /path/to/uploads,再确保其属组是 www-data
/var/www —— vendor/ 下某些脚本或扩展可能依赖更严格的权限(如 composer.lock 写入失败)权限不是改一次就永远有效,尤其当代码自动创建子目录或日志轮转时,新生成的文件很可能继承错误的 umask 或属主。定期用 find /path -type d -not -perm 755 和 find /path -type f -not -perm 644 扫描异常项,比等报错再救火更省事。