0

0

CodeIgniter结构响应中如何处理AJAX请求_CodeIgniterAJAX响应构建【说明】

絕刀狂花

絕刀狂花

发布时间:2026-03-12 19:31:31

|

306人浏览过

|

来源于php中文网

原创

CodeIgniter 3 中返回 JSON 必须先调用 $this->output->set_content_type() 再 set_output(),不可手动 echo 或 exit;AJAX 判断应优先用 HTTP_ACCEPT 或自定义头而非 is_ajax_request();CSRF 需前端读取 meta token 并通过 X-CSRF-TOKEN 透传。

codeigniter结构响应中如何处理ajax请求_codeigniterajax响应构建【说明】

CodeIgniter 3 中 $this->output->set_content_type() 必须在 send() 前调用

很多人在 AJAX 响应里返回 JSON 却得不到正确 Content-Type: application/json,浏览器仍当 HTML 解析——根本原因是 set_content_type() 被调在了 echo json_encode(...) 之后,或被 exit / die 中断了输出流程。

CodeIgniter 的输出类是延迟写入的,所有 set_* 方法(如 set_status()set_content_type())必须在最终响应发送前生效。一旦你手动 echoprint,CI 就不再接管 header 和 content-type。

  • ✅ 正确做法:先设类型、状态,再用 $this->output->set_output() 注入内容,最后让 CI 自动 send
  • ❌ 错误写法:header('Content-Type: application/json'); echo json_encode([...]); exit; —— 绕过了 CI 输出机制,CSRF、缓存控制等全失效
  • ⚠️ 注意:set_content_type('json') 是简写,内部等价于 set_content_type('application/json', 'utf-8');显式写全更稳妥,尤其涉及中文时

AJAX 请求下 $this->input->is_ajax_request() 不可靠,优先用 HTTP 头判断

is_ajax_request() 只检查 HTTP_X_REQUESTED_WITH 是否为 XMLHttpRequest,但现代前端框架(如 Vue + Axios、React + Fetch)默认不带这个头,某些 CDN 或代理还会剥离它——结果就是明明是 AJAX 请求,却进了非 AJAX 分支。

更稳的方式是结合 $_SERVER['HTTP_ACCEPT'] 或自定义请求头(如 X-Requested-With: Fetch),尤其在前后端分离项目中。

  • ✅ 推荐判断逻辑:strpos($_SERVER['HTTP_ACCEPT'] ?? '', 'application/json') !== false
  • ✅ 或统一约定加头:axios.defaults.headers.common['X-AJAX'] = 'true',后端用 $this->input->get_request_header('X-AJAX') === 'true'
  • ⚠️ 不要依赖 is_ajax_request() 做权限/流程分支,它只是辅助提示,不是安全边界

CSRF 保护开启时,AJAX POST 必须携带 csrf_test_name 字段或头

CodeIgniter 默认开启 CSRF,表单提交自动注入隐藏字段,但 AJAX 不会自动读取并带上它——导致 403 或空白响应,且无明确错误提示。

腾讯交互翻译
腾讯交互翻译

腾讯AI Lab发布的一款AI辅助翻译产品

下载

关键不是“关掉 CSRF”,而是让前端能拿到并透传 token。CI 把 token 存在 session 里,每次刷新页面都会变,所以不能硬编码。

  • ✅ 后端在视图里暴露 token:<meta name="csrf-token" content="<?php echo $this->security->get_csrf_hash(); ?>">
  • ✅ 前端 JS 读取并设置:headers['X-CSRF-TOKEN'] = document.querySelector('meta[name="csrf-token"]').getAttribute('content')
  • ✅ CI 配置需启用头支持:$config['csrf_token_name'] = 'csrf_test_name'; $config['csrf_cookie_name'] = 'csrf_cookie_name';,并在 application/config/config.php 中确保 $config['csrf_protection'] = TRUE;
  • ⚠️ 如果用 $.ajaxSetup() 全局加头,注意避免对跨域请求误加(会触发预检失败)

返回 JSON 时别直接 json_encode($data),用 $this->output->set_output() 统一出口

直接 echo json_encode() 看似快,但绕过 CI 输出类后,你失去三样东西:自动 GZIP 压缩(如果启用)、统一的 HTTP 状态码控制、以及后续钩子(如日志记录、性能统计)的执行机会。

而且 CI 的 set_output() 会自动处理字符编码和换行,比手写更健壮。

  • ✅ 推荐写法:$this->output->set_status_header(200)->set_content_type('application/json', 'utf-8')->set_output(json_encode(['status' => 'success', 'data' => $result], JSON_UNESCAPED_UNICODE));
  • ✅ 如果需要压缩,确认 $config['compress_output'] = TRUE; 已开启,CI 会在发送前自动 gzip
  • ⚠️ JSON_UNESCAPED_UNICODE 很重要,否则中文变成 \u4f60\u597d,前端还得额外 decode

真正容易被忽略的是:CI 的输出类只在完整生命周期结束时才真正 send,所以中间任何 echovar_dump、未捕获的 Notice 都会导致 headers already sent 错误——调试时用 log_message('debug', ...),别手欠打 print_r

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

456

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

547

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

257

2024.09.24

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

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

76

2026.03.11

热门下载

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

精品课程

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

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