0

0

composer安装yii框架教程_使用composer部署yii项目环境【实操】

穿越時空

穿越時空

发布时间:2026-03-16 15:22:01

|

687人浏览过

|

来源于php中文网

原创

默认安装的 Yii 版本可能非最新,因 yii2-app-basic 的 latest stable tag 滞后于最新补丁;Yii 2 与 Yii 3 不兼容,需区分 yiisoft/yii2-app-basic(Yii 2)和 yiisoft/yii-project-template(Yii 3);指定版本号如 2.0.48 更稳妥;务必使用 --prefer-dist;vendor/autoload.php 缺失、runtime/assets 权限不足、Apache 重写规则未生效是三大高频问题。

composer安装yii框架教程_使用composer部署yii项目环境【实操】

composer create-project 装出来的不是最新 Yii 版本?

默认执行 composer create-project --prefer-dist yiisoft/yii2-app-basic basic 会拉取 yii2-app-basic 的 latest stable tag,但这个 tag 可能滞后于 2.0.x 最新补丁(比如 2.0.48 已发布,但 tag 还卡在 2.0.47)。更麻烦的是,Yii 2 和 Yii 3 完全不兼容,yiisoft/yii2-app-basicyiisoft/yii-project-template 是两套东西,搜错关键词就装错框架。

  • 查清你要的版本:Yii 2 用 yiisoft/yii2-app-basicyiisoft/yii2-app-advanced;Yii 3 用 yiisoft/yii-project-template(注意没有 “2”)
  • 指定版本号更稳妥,例如装 Yii 2.0.48:composer create-project --prefer-dist yiisoft/yii2-app-basic basic 2.0.48
  • 装 Yii 3(PHP 8.0+):composer create-project --prefer-dist yiisoft/yii-project-template myapp,别漏掉 --prefer-dist,否则可能拉源码而非预编译包,后续 composer install 更慢

vendor/autoload.php 找不到或报 Class not found

常见于手动移动项目目录、改名后没重跑 autoload,或 composer install 被跳过。Yii 启动入口(如 web/index.php)第一行就是 require(__DIR__ . '/../vendor/autoload.php');,这个文件不存在或路径不对,直接 500。

  • 确认当前目录下有 vendor/ 文件夹,且里面有 autoload.php;没有就说明 composer install 没成功跑完
  • 别用 cp -r 复制整个项目去生产环境——vendor/ 是平台相关生成物,必须在目标机器上重新 composer install --no-dev
  • 如果提示 Class 'Yii' not found,检查 vendor/autoload.php 是否真包含 Yii 的 PSR-4 映射(打开看有没有 'Yii' => ...),极少数情况是 Composer 配置损坏,删掉 vendor/composer.lock 重装

权限问题导致 runtime/ 或 assets/ 写入失败

Yii 运行时要往 runtime/(日志、缓存)和 assets/(资源包发布)写文件,Web 服务器用户(如 www-data_www)没权限就会报 Failed to write file 或白屏无错误。

社研通
社研通

文科研究生的学术加速器

下载
  • Linux/macOS 下,进项目根目录执行:chmod 775 runtime assets,再 chown -R $USER:www-data runtime assets(把组设为 Web 用户组)
  • Windows WAMP/XAMPP 通常不用调权限,但若用 Docker,得确保容器内 Web 用户对这两个目录有写权,可在 DockerfileRUN chown -R www-data:www-data /app/runtime /app/assets
  • 别把 chmod 777 当万能解——它会让 runtime 目录暴露可执行风险,尤其线上环境

Apache 伪静态规则没生效,访问 index.php 路由 404

Yii 默认用 PATH_INFO 模式,URL 如 /index.php/site/about,但启用美化 URL 后要靠 Web 服务器重写支持 /site/about。Apache 下没开 mod_rewrite 或没配 .htaccess,就会 404。

  • 先确认 Apache 开了重写模块:a2enmod rewrite(Debian/Ubuntu),然后重启 apache2
  • 确保项目 web/ 目录下有 .htaccess(Yii 2 模板自带,Yii 3 默认不带,需手动加)
  • 关键点:Apache 虚拟主机配置里必须允许 .htaccess 覆盖,即 <directory> AllowOverride All </directory>,仅设 AllowOverride None 会导致规则被忽略

runtime/ 目录权限、autoload 加载链、重写规则生效条件——这三个地方出问题,比代码逻辑错更难定位,因为没报错或只报错半句。动手前先盯住它们。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

162

2023.12.25

require的用法
require的用法

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

510

2023.11.27

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

931

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1539

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1172

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

837

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

463

2023.08.02

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7.6万人学习

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

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