在 WordPress 中使用 Composer 管理主题、插件或自定义库不会干扰其核心自动更新功能,前提是不将 WordPress 核心文件纳入 Composer 管理,且安装路径限定在 wp-content 下的子目录(如 plugins 或 themes),并正确配置 composer.json 的 installer-paths 和包类型。

在 WordPress 项目中使用 Composer 不会干扰其核心自动更新功能,只要你不把 WordPress 核心文件本身交给 Composer 管理(比如不通过 composer require wordpress/wordpress 引入),而是仅用 Composer 管理主题、插件或自定义 PHP 库,就能安全共存。
WordPress 自动更新机制只作用于它自己识别的目录结构(如 wp-admin、wp-includes、wp-content/plugins 和 wp-content/themes)。只要你把 Composer 的安装目标设为这些目录下的子路径(例如 wp-content/plugins/my-plugin),而不是覆盖 wp-admin 或 wp-includes,就不会冲突。
wp-content 下初始化 Composer 项目,用 "type": "wordpress-plugin" 或 "type": "wordpress-theme" 声明包类型,并配合 composer/installers 自动归位关键在于明确声明哪些内容由 Composer 管理,哪些交给 WordPress 自己处理。一个典型的安全配置如下:
wordpress/core 类型的包(如 johnpbloch/wordpress),除非你主动放弃后台更新,改用 CLI 更新"installer-paths" 规则,确保插件/主题被装进 wp-content/plugins/xxx 或 wp-content/themes/xxx,而非根目录"minimum-stability": "stable" 和 "prefer-stable": true,防止开发版依赖意外破坏兼容性只要 wp-admin 和 wp-includes 是原始 WordPress 官方分发文件(哪怕你是手动上传或通过其他工具部署),后台的“更新”页面就照常工作。Composer 只负责它知道的路径,不会修改 version.php 或 wp_get_theme() 的行为。
wp-config.php 或重写了 wp-settings.php,需确保未屏蔽 WP_AUTO_UPDATE_CORE 或禁用 wp_version_check()
以管理一个自研插件为例:
wp-content 目录下运行 composer init
composer require myorg/my-plugin:dev-main
composer.json 中配置安装路径:"extra": {
"installer-paths": {
"plugins/{$name}/": ["type:wordpress-plugin"]
}
}composer update 后,插件自动出现在 wp-content/plugins/my-plugin,后台插件列表和自动更新不受影响基本上就这些。Composer 和 WordPress 自动更新不是互斥关系,而是分工关系:一个管“我写的代码”,一个管“WordPress 自己的代码”。只要边界清晰,两者完全能和平共处。
以上就是如何在WordPress项目中使用Composer而不影响其自动更新功能?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号