0

0

Composer create-project 命令是如何工作的? (项目脚手架)

尼克

尼克

发布时间:2026-01-12 03:29:31

|

632人浏览过

|

来源于php中文网

原创

composer create-project 是模板实例化而非包管理,它克隆完整项目(含文件结构和自动初始化),仅支持 type=project 的包,通过 post-create-project-cmd 执行初始化脚本,不覆盖非空目录。

composer create-project 命令是如何工作的? (项目脚手架)

create-project 不是安装依赖,而是克隆一个完整项目

它和 composer require 有本质区别:后者往现有项目里加库,前者是从头拉一个「能直接跑的项目副本」。比如你执行 composer create-project laravel/laravel myapp,Composer 并不会只写个 composer.json 然后装包——它会从 Packagist 找到 laravel/laravel 对应的发布包(通常是 zip 压缩包),解压全部文件(含 app/routes/artisan 等),再进目录自动运行 composer install

  • 整个过程相当于手动 git clone + composer install + 初始化脚本,但全自动
  • 模板包必须是 "type": "project" 类型(如 laravel/laravelsymfony/skeleton),普通库包("type": "library")不支持
  • 如果目标目录已存在且非空,命令会直接报错退出,不会覆盖

它怎么触发初始化动作?靠 post-create-project-cmd 脚本

很多框架模板会在自己的 composer.json 里定义 "post-create-project-cmd" 钩子,比如 Laravel 就用它自动生成 APP_KEY、重命名 .env.example.env。这个脚本在 composer install 完成后立即执行。

  • 如果你不想让它运行(比如想跳过密钥生成做自动化部署),加 --no-scripts
  • 钩子失败会导致整个命令中断,所以模板作者通常会加错误处理,比如用 @php -r "copy('env.example', '.env') ?: print('skip .env copy');"
  • 注意:这个钩子只在 create-project 时触发,composer installupdate 不会调用

--prefer-dist 和 --prefer-source 到底选哪个?

默认行为是优先走 --prefer-dist(下载 zip 包),速度快、不依赖 Git;而 --prefer-source 会尝试 clone Git 仓库,适合你要改框架源码或调试内部逻辑。

ImgCreator AI
ImgCreator AI

一款AI图像生成工具,适合创建插图、动画和概念设计图像。

下载
  • --prefer-dist:适合绝大多数场景,尤其是 CI/CD 或生产环境初始化
  • --prefer-source + --keep-vcs:组合使用才能保留 .git 目录,方便后续提交或切分支
  • 某些私有模板没发 dist 包(只推了 Git tag),此时即使加 --prefer-dist 也会 fallback 到 source

常见卡点和绕过方式

最常遇到的是网络慢、权限错、版本不匹配——不是命令本身复杂,而是环境链路太长。

  • 卡在 “Installing dependencies”:先试 -vvv 看具体卡在哪一步;国内用户务必配镜像:
    composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
  • “Could not find package”:检查包名是否拼错,或版本号格式不对(比如写成 10.x 而不是 "10.*",引号不能少)
  • PHP 版本不兼容:用 --ignore-platform-reqs 强行过,但不推荐;更稳妥的是先确认模板文档要求的 PHP 版本,再调环境
  • 想把项目建到当前目录(不新建文件夹):目录名填 .,但当前目录必须为空,否则报错
真正容易被忽略的是:**create-project 的本质是「模板实例化」,不是「包管理」**。它依赖模板包自身是否健壮——如果那个 composer.json 里漏写了 autoload、scripts 写死路径、或 post-create-project-cmd 没做容错,你拿到的就是一个半残项目。所以选模板时,别只看 star 数,得看它的 composer.json 和最近 release 是否干净。

相关专题

更多
php文件怎么打开
php文件怎么打开

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

2404

2023.09.01

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

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

1550

2023.10.11

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

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

1449

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数据库相关内容,可以阅读本专题下面的文章。

1414

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中文网欢迎大家前来学习。

1305

2023.11.13

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

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

80

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号