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/ 也塞进文档里,结果是生成巨慢 + 报一堆“找不到父类”警告。必须显式限定源码路径和排除规则。

<?xml version="1.0" encoding="UTF-8" ?>
<phpdocumentor
    configVersion="3"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="https://www.phpdoc.org"
    xsi:noNamespaceSchemaLocation="https://raw.githubusercontent.com/phpDocumentor/phpDocumentor/v3/data/xsd/phpdoc.xsd"
>
    <paths>
        <output>docs/api</output>
        <cache>docs/cache</cache>
    </paths>
    <project>
        <filesets>
            <fileset name="source">
                <directory>src</directory>
                <exclude>src/Tests</exclude>
                <exclude>src/Example</exclude>
            </fileset>
        </filesets>
    </project>
</phpdocumentor>
  • <directory></directory> 值必须是相对于 phpdoc.xml 所在路径的相对路径,不是 Composer 根目录
  • 排除路径用 <exclude></exclude>,不是正则;写 tests/ 不如写 src/Tests 明确
  • 输出目录(<output></output>)建议设为 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,比靠人想起来更可靠。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

950

2023.08.02

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

508

2023.11.27

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1942

2024.04.01

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

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

精品课程

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

共137课时 | 13万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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