0

0

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

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-09 16:57:08

|

447人浏览过

|

来源于php中文网

原创

必须安装phpdocumentor/phpdocumentor为开发依赖,配置phpdoc.xml限定源码路径并排除无关目录,通过composer.json scripts固化命令,注意注释规范与缓存优化。

如何使用composer为你的php库生成api文档? (脚本自动化)

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% 出在注释格式或符号解析上,而不是代码本身。

CG Faces
CG Faces

免费的 AI 人物图像素材网站

下载

立即学习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文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2308

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1521

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1414

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

951

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1413

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1233

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1304

2023.11.13

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号