CodeIgniter 4 仍值得使用,尤其适合微服务网关、内部工具等场景;支持隐藏 index.php(需配置重写规则);$this->db->query() 与 get() 适用场景不同,非单纯性能差异;Filters 需显式绑定路由;兼容 Composer 生态;不预设工程决策,灵活性高。

CodeIgniter 仍然值得用——尤其当你需要一个不拖累部署、不绑架架构、不强制你学新概念的 PHP 框架时。
它不是过时,而是“被低估”:在微服务网关、内部工具、政企旧系统对接、低配 VPS 上跑的管理后台等场景里,CI4(当前最新稳定版)的启动耗时、内存占用、错误堆栈清晰度,反而比 Laravel 或 Symfony 更贴近真实交付需求。
CI4 的 index.php 入口还能手动删掉吗?
能,但不建议直接删。CI4 默认仍走 index.php 路由入口,这是为兼容老旧主机和简化重写规则留的余量。真要隐藏,得配好 Apache 的 .htaccess 或 Nginx 的 try_files,否则会 404。
- Apache 下确保
mod_rewrite已启用,.htaccess中包含标准重写规则(CI4 官方提供) - Nginx 需在 server 块中加:
location / { try_files $uri $uri/ /index.php?$query_string; } - 删了
index.php却没配重写 → 所有路由返回 404,且错误页不显示具体原因(CI4 默认关闭调试时静默失败)
$this->db->query() 和 $this->db->get() 性能差多少?
不是“差多少”,是“适用场景完全不同”。前者是裸 SQL 执行器,后者是 Query Builder 封装,本质不是性能问题,而是可维护性与安全边界问题。
- 用
$this->db->query("SELECT * FROM users WHERE id = {$id}")→ 直接 SQL 注入风险,CI4 不做自动转义 - 正确写法是:
$this->db->query("SELECT * FROM users WHERE id = ?", [$id]);或更推荐:$this->db->where('id', $id)->get('users'); - Query Builder 在复杂 JOIN 或动态条件拼接时,代码可读性高;但纯静态 SQL(如报表导出)用
query()+ 绑定参数反而更直白
为什么 CI4 的 Filters 经常不生效?
因为 Filter 必须显式绑定到路由组或单个路由,且顺序敏感——它不像 Laravel 中间件那样全局默认挂载。
- 定义 Filter 后,必须在
app/Config/Filters.php中注册别名,并在$aliases数组里映射 - 然后在
app/Config/Routes.php中用$routes->group(['filter' => 'auth'], function($routes){...})包裹受控路由 - 常见坑:忘记在
Filters.php的$globals数组里启用'before'或'after'全局钩子,导致登录态校验类 Filter 完全不触发
CI4 还能和 Composer 生态共存吗?
能,而且比 CI3 更自然。CI4 本身就是用 Composer 加载核心组件的,app/Config/Autoload.php 里的 psr4 配置支持自定义命名空间,第三方包可直接 require。
- 例如引入
monolog/monolog:composer require monolog/monolog
,然后在控制器中use Monolog\Logger;
即可使用 - 注意:CI4 的 autoloader 默认只扫描
app/目录,若第三方类需扩展 CI 类(如自定义Model基类),要在Autoload.php中补上对应psr4映射 - 别硬套 Laravel 的 Service Provider 模式——CI4 没有自动发现机制,所有依赖注入都得手动在
app/Config/Services.php里注册
CI4 最容易被忽略的一点:它不帮你做“工程决策”,只提供最小契约。这意味着你得自己决定日志怎么落盘、缓存用 Redis 还是文件、错误是否上报 Sentry——没有开箱即用的“最佳实践”,只有明确的接口和文档。这恰恰是它在运维敏感、合规强约束项目里仍被悄悄选用的原因。










