欢迎光临南昌笑劳网络科技有限公司,我们是一家专注中小型企业营销推广服务的公司!

咨询热线:400 76543 55
南昌笑劳网络科技有限公司
最新资讯News
南昌笑劳网络科技有限公司

如何使用Composer为你的PHP库生成API文档? (脚本自动化)

作者:裘德小鎮的故事 | 点击: | 来源:裘德小鎮的故事
0901
2026
必须安装phpdocumentor/phpdocumentor为开发依赖,配置phpdoc.xml限定源码路径并排除无关目录,通过composer.jsonscripts固化命令,注意注释规范与缓存优化。...
必须安装phpdocumentor/phpdocumentor为开发依赖,配置phpdoc.xml限定源码路径并排除无关目录,通过composer.json scripts固化命令,注意注释规范与缓存优化。

用 phpdocumentor 生成 API 文档前必须确认的依赖项

Composer 本身不生成文档,真正干活的是 phpdocumentor/phpdocumentor。你得先把它作为开发依赖装进项目里,而不是全局安装——否则 CI/CD 流水线或他人本地构建时容易失败。

  • 运行 composer require --dev phpdocumentor/phpdocumentor(v3 推荐,PHP 7.4+)
  • 确保 vendor/bin/phpdoc 可执行;若报错“command not found”,检查 vendor/bin/ 是否在 $PATH 中,或直接用 php vendor/bin/phpdoc
  • v2 已停止维护,别再用 phpdocumentor/phpdocumentor:2.*,它不支持 PHP 8.1+ 的属性语法(如 #[\Attribute]

配置 phpdoc.xml 避免扫描错误目录

默认会扫整个项目,把 tests/vendor/build/ 也塞进文档里,结果是生成巨慢 + 报一堆“找不到父类”警告。必须显式限定源码路径和排除规则。



    
        docs/api
        docs/cache
    
    
        
            
                src
                src/Tests
                src/Example
            
        
    
  • 值必须是相对于 phpdoc.xml 所在路径的相对路径,不是 Composer 根目录
  • 排除路径用 ,不是正则;写 tests/ 不如写 src/Tests 明确
  • 输出目录()建议设为 docs/api,方便 GitHub Pages 直接托管

在 composer.json 的 scripts 里加一键命令

把生成逻辑固化到 composer.json,别人 clone 代码后只需 composer install && composer docs,不用翻 README 记命令。

"scripts": {
    "docs": [
        "php vendor/bin/phpdoc --config=phpdoc.xml",
        "chmod -R a+r docs/api"
    ]
}
  • 第二行 chmod 是给 CI 用的:某些 Linux 环境生成的 HTML 文件权限为 600,GitHub Pages 无法读取
  • 不要写成 "docs": "php vendor/bin/phpdoc --config=phpdoc.xml 2>&1" —— 屏蔽错误会掩盖真实问题,比如注释语法写错(@param string $foo 漏了变量名)
  • 如果想每次 git push 后自动更新文档,CI 配置里调用 composer docs 即可,无需额外 shell 脚本

常见报错与绕过技巧

生成失败时,90% 出在注释格式或符号解析上,而不是代码本身。

立即学习“PHP免费学习笔记(深入)”;

  • Unable to find the class "FooInterface":说明 use 语句缺失,或接口没被 autoload 加载;检查 composer.json"autoload" 是否覆盖了 src/ 下所有命名空间
  • Invalid tag "@return void":v3 默认禁用 @return void,删掉即可;void 类型函数不必写 @return
  • 生成 HTML 很慢?加 --cache-folder=docs/cache 复用缓存,首次之后快 3–5 倍
  • 想跳过某个类不生成文档?在类 DocBlock 顶部加 /** @internal */,phpDocumentor 会自动忽略

文档生成不是一劳永逸的事,只要改了 public 方法签名或新增了接口,就得重新跑一次。把 composer docs 嵌进 pre-commit hook 或 CI,比靠人想起来更可靠。


# php  # class  # public  # internal  # Attribute  # 自动化  # 文档  # 报错  # 里加  # 装进  # 的是  # 而不是  # 首次  # 找不到  # 只需  #   # 接口  # linux  # html  # js  # git  # json  # composer  # github  # String  # 命名空间  # 父类  # require  # xml  # Directory  # void  # 设为 

我要咨询做网站
成功案例
建站流程
  • 网站需
    求分析
  • 网站策
    划方案
  • 页面风
    格设计
  • 程序设
    计研发
  • 资料录
    入优化
  • 确认交
    付使用
  • 后续跟
    踪服务
  • 400 76543 55
    sale#ncxiaolao.cn
Hi,Are you ready?
准备好开始了吗?
那就与我们取得联系吧

咨询送礼现在提交,将获得笑劳科技策划专家免费为您制作
价值5880元《全网营销方案+优化视频教程》一份!
下单送礼感恩七周年,新老用户下单即送创业型空间+域名等大礼
24小时免费咨询热线400 76543 55
合作意向表
您需要的服务
您最关注的地方
预算

直接咨询