0

0

CodeIgniter安装Apache虚拟主机设置_CodeIgniter虚拟主机配置方法【指南】

雪夜

雪夜

发布时间:2026-03-12 21:01:03

|

580人浏览过

|

来源于php中文网

原创

Apache虚拟主机DocumentRoot必须指向public目录,因CI4的index.php位于public下;需配置AllowOverride All、启用mod_rewrite、设置APP_ENV和APP_DEBUG环境变量,并确保base_url()路径与实际资源位置一致。

codeigniter安装apache虚拟主机设置_codeigniter虚拟主机配置方法【指南】

Apache 虚拟主机 DocumentRoot 必须指向 public 目录

CodeIgniter 4 默认把入口文件 index.php 放在 public 子目录里,不是项目根目录。如果 Apache 的 DocumentRoot 指向项目根(比如 /var/www/myapp),用户访问时会直接看到目录列表或 403 错误——因为 index.php 不在 Web 可访问路径下。

正确做法是把 DocumentRoot 明确设为 public 目录:

DocumentRoot "/var/www/myapp/public"
<Directory "/var/www/myapp/public">
    AllowOverride All
    Require all granted
</Directory>
  • AllowOverride All 是必须的,否则 .htaccess 里的重写规则不生效
  • 别漏掉 <Directory> 块,否则即使路径对了也会返回 403
  • 修改后要 sudo systemctl reload apache2(Ubuntu/Debian)或 sudo apachectl graceful(macOS)才生效

启用 mod_rewrite 并确认 .htaccess 生效

CodeIgniter 依赖 URL 重写隐藏 index.php。常见现象是:首页能打开,但点击“About”或任何其他路由就 404——本质是 Apache 没转发请求到 index.php

检查三件事:

  • 运行 a2enmod rewrite 启用模块(Ubuntu/Debian),或确认 LoadModule rewrite_module modules/mod_rewrite.sohttpd.conf 中未被注释(macOS / CentOS)
  • AllowOverride 必须设为 All(不能是 NoneFileInfo),否则 .htaccess 被忽略
  • public/.htaccess 文件必须存在且内容完整(CI4 官方包自带,别手动删或清空)

一个快速验证方式:在 public/.htaccess 末尾加一行 Redirect 302 /test-rewrite 1,访问 /test-rewrite 看是否跳转。不跳?说明重写根本没走。

APP_ENVAPP_DEBUG 要在 Apache 环境变量中显式设置

CodeIgniter 4 从环境变量读取 APP_ENVAPP_DEBUG,而不是靠 .env 文件自动加载(尤其在 CLI 或 Apache 下)。如果没设,APP_ENV 默认是 productionAPP_DEBUG=false,导致错误全被吞掉,只显示白屏或 “Whoops!” 页面。

绘蛙
绘蛙

电商场景的AI创作平台,无需高薪聘请商拍和文案团队,使用绘蛙即可低成本、批量创作优质的商拍图、种草文案

下载

在虚拟主机配置里加这两行:

SetEnv APP_ENV development
SetEnv APP_DEBUG true
  • 别写成 SetEnv APP_DEBUG "true" —— 字符串 "true" 在 PHP 中仍为 true,但 CI4 内部用的是严格字符串比较,只认小写 true(无引号)
  • 生产环境务必改回 SetEnv APP_DEBUG false,否则敏感信息可能泄露
  • 如果用的是 PHP-FPM,这些变量得通过 php_admin_value[env[APP_ENV]] 方式传,不是 SetEnv

URL 重写后 CSS/JS 资源 404?检查 base_url() 和静态资源路径

虚拟主机配好、重写也通了,但页面样式错乱、控制台报一堆 GET /css/app.css 404 —— 这不是 Apache 配置问题,而是 CodeIgniter 的资源路径生成逻辑没对齐。

关键点:

  • base_url() 默认返回的是当前域名根路径(如 https://app.local/),所以 base_url('css/app.css') 生成的是 /css/app.css
  • 但你的 CSS 实际放在 public/css/app.css,而 Apache 的 DocumentRoot 已经是 public,所以这个路径是对的
  • 真正出问题的情况是:你把资源放到了 public/assets/css/,却还用 base_url('css/app.css') —— 少写了 assets/
  • 或者你在 .env 里改了 app.baseURL,但值末尾没加 /(如写成 app.baseURL=https://app.local),会导致所有资源路径拼接错误

建议统一用 base_url('assets/css/app.css'),并在 public/ 下建 assets/ 目录放所有前端资源,避免和框架默认路径冲突。

路径层级和环境变量传递这种事,看着琐碎,但少设一个 SetEnv 或多写一个斜杠,调试两小时都未必想到点上。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

131

2025.08.07

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

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

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