dump-autoload --strict-psr 作用是生成自动加载映射时跳过所有不符合 PSR-4 或 PSR-0 标准的类文件声明,仅影响 autoload 配置,不检查 autoload-dev,也不修复问题,仅作合规性校验。

dump-autoload --strict-psr 是什么作用
它不是强制你写符合 PSR-4 或 PSR-0 的代码,而是让 composer dump-autoload 在生成自动加载映射时,**跳过所有不符合 PSR 标准的类文件声明**。比如你写了 "psr-4": {"App\\": "src/"},但 src/Helper.php 里定义的是 class StringUtils(而非 class App\Helper\StringUtils),这个类在 --strict-psr 模式下会被直接忽略,不会出现在 vendor/composer/autoload_psr4.php 中。
什么时候必须加 --strict-psr
当你遇到以下情况之一时,加这个参数能提前暴露问题:
- 类文件被自动加载了,但运行时报
Class not found—— 实际可能是命名空间与路径不匹配,而普通 autoload 没报错,只是静默跳过 - CI 流程中想卡住不规范的类注册,避免“本地能跑、线上挂掉”
- 团队正在迁移旧项目,需要逐步清理非 PSR-4 风格的类组织方式
--strict-psr 和 autoload-dev 的关系
它只影响 "autoload" 下的配置(如 psr-4、psr-0、classmap),对 "autoload-dev" 里的路径**完全不生效**。也就是说,你在 autoload-dev 里写了个 "psr-4": {"Tests\\": "tests/"},即使测试类命名不规范,--strict-psr 也不会检查它。
如果你真想连测试也校验,得把测试路径挪到主 autoload 里(不推荐),或改用静态分析工具如 phpstan + 自定义规则。
常见误用和坑
很多人以为加了 --strict-psr 就能“自动修好”PSR 问题,其实它只是开关,不是修复器。容易踩的点有:
- 用了
classmap映射单个文件(比如"classmap": ["src/functions.php"]),而该文件里有类定义——--strict-psr会直接忽略整个classmap块,导致函数也无法加载 - 在
composer.json中混用psr-4和psr-0,其中某条规则路径重叠,--strict-psr可能因顺序问题漏掉部分类 - 执行后没报错,不代表没问题:它只检查“声明是否合规”,不检查“文件是否存在”或“类名是否拼错”
最稳妥的做法是先运行 composer dump-autoload --strict-psr --no-cache,再配合 composer show -p 看实际加载了哪些命名空间,比单纯依赖是否报错更可靠。










