CodeIgniter自定义JSON数组输出教程
时间:2025-11-04 11:21:33 200浏览 收藏
最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《CodeIgniter自定义JSON数组输出方法》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

本文旨在指导开发者如何在CodeIgniter框架中,将从数据库获取的关联数组数据,转换并重构为前端或API所需的特定嵌套JSON数组格式。通过详细的代码示例,演示如何处理日期字符串到Unix时间戳的转换,以及数字字符串到浮点数的转换,最终生成符合要求的JSON输出,以满足复杂的数据结构需求。
在Web应用开发中,尤其是在构建API接口时,我们经常需要将后端数据以特定的JSON格式返回给前端。CodeIgniter框架通常通过模型从数据库获取数据,这些数据默认以关联数组或对象数组的形式存在。然而,前端或某些图表库可能需要更紧凑或特定结构的JSON数据,例如一个包含时间戳和数值的二维数组。
初始数据结构与默认JSON编码
假设我们从模型中获取了一组发票数据,其结构可能如下所示,其中包含 date_issued(日期字符串)和 grand_total(总金额字符串):
// 假设 $invoices 是从模型获取的数据
$invoices = [
['date_issued' => '2021-03-01', 'grand_total' => '972.948'],
['date_issued' => '2021-03-12', 'grand_total' => '1025.88']
];
// 直接使用 json_encode 进行编码
$response['price'] = $invoices;
echo json_encode($response, TRUE);这段代码会生成以下JSON输出:
{"price":[{"date_issued":"2021-03-01","grand_total":"972.948"},{"date_issued":"2021-03-12","grand_total":"1025.88"}]}然而,如果前端期望的格式是这样的:
{
"price": [
[
1483275269000, // Unix时间戳 (毫秒)
972.948
],
[
1483361668000,
1025.88
]
]
}我们可以看到,默认的JSON编码并没有满足以下两点要求:
- 数据结构变化: 期望的是一个二维数组,内部数组只包含值,而不是键值对。
- 数据类型转换: date_issued 需要转换为Unix时间戳(通常是毫秒级),grand_total 需要转换为浮点数。
数据重构与类型转换
为了达到期望的JSON格式,我们需要在json_encode之前对数据进行手动处理。核心思想是遍历原始数据,针对每个字段进行必要的类型转换,并构建一个新的嵌套数组结构。
以下是实现这一转换的PHP代码:
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Invoice extends CI_Controller {
public function __construct() {
parent::__construct();
$this->load->model('invoice_model'); // 假设已加载模型
}
public function get_price_data() {
// 假设 logged('company_id') 获取当前公司ID
$company_id = logged('company_id');
$invoices = $this->invoice_model->getAllData2($company_id);
$temp = []; // 用于存储转换后的数据
foreach ($invoices as $key1 => $value1) {
$row_data = []; // 存储当前记录的转换结果
foreach ($value1 as $key2 => $value2) {
switch ($key2) {
case 'date_issued':
// 将日期字符串转换为Unix时间戳(秒),然后乘以1000得到毫秒
// 注意:strtotime 返回的是秒级时间戳
$row_data[] = strtotime($value2) * 1000;
break;
case 'grand_total':
// 将字符串转换为浮点数
$row_data[] = floatval($value2);
break;
default:
// 忽略其他不需要的字段,或者根据需要处理
break;
}
}
// 将处理后的行数据添加到 $temp 数组中
$temp[] = $row_data;
}
$response['price'] = $temp;
// 使用 json_encode 编码最终结果,第二个参数 TRUE 用于美化输出(PHP 5.4+)
// 如果不需要美化,可以省略 TRUE 或使用 JSON_PRETTY_PRINT 选项
header('Content-Type: application/json'); // 设置响应头为JSON
echo json_encode($response, JSON_NUMERIC_CHECK | JSON_PRETTY_PRINT);
}
}代码解析:
- $temp = [];: 初始化一个空数组,用于存放最终重构的数据。
- 外层 foreach ($invoices as $key1 => $value1): 遍历从模型中获取的每一条发票记录。$value1 在这里代表单条发票的关联数组,例如 ['date_issued' => '2021-03-01', 'grand_total' => '972.948']。
- $row_data = [];: 在处理每条发票记录之前,初始化一个空数组来存储该记录转换后的 [时间戳, 金额] 对。
- 内层 foreach ($value1 as $key2 => $value2): 遍历当前发票记录的各个字段。
- switch ($key2): 根据字段名进行条件判断和处理。
- case 'date_issued': 使用 strtotime($value2) 将日期字符串转换为Unix时间戳(秒)。由于前端可能需要毫秒级时间戳,这里乘以 1000。
- case 'grand_total': 使用 floatval($value2) 将字符串形式的总金额转换为浮点数。
- default: 对于其他不需要包含在最终JSON中的字段,可以忽略。
- $row_data[] = ...: 将转换后的值依次添加到 $row_data 数组中,这样就形成了 [时间戳, 金额] 的结构。
- $temp[] = $row_data;: 将处理好的 $row_data (即 [时间戳, 金额] 数组)添加到 $temp 数组中,从而构建出 [[时间戳1, 金额1], [时间戳2, 金额2]] 的二维数组结构。
- $response['price'] = $temp;: 将重构后的 $temp 数组赋值给 $response 的 price 键。
- header('Content-Type: application/json');: 确保浏览器或客户端正确解析响应内容为JSON。
- echo json_encode($response, JSON_NUMERIC_CHECK | JSON_PRETTY_PRINT);:
- JSON_NUMERIC_CHECK: 自动将数字字符串编码为JSON数字类型,而不是字符串。这对于确保 grand_total 即使在原始数据中是字符串也能被正确识别为数字非常有用。
- JSON_PRETTY_PRINT: 使JSON输出格式化,更易读。在生产环境中,为了减少响应大小,通常会省略此选项。
注意事项与最佳实践
- 数据类型匹配: 始终确保将数据转换为前端期望的精确类型(例如,整数、浮点数、布尔值)。PHP的 intval(), floatval(), boolval() 等函数非常有用。
- 时间戳精度: strtotime() 返回的是秒级时间戳。如果前端需要毫秒级,务必乘以 1000。对于更精确的时间处理,可以考虑使用 DateTime 对象。
- 错误处理: 在实际应用中,应考虑 strtotime() 可能返回 false 的情况(例如,无效的日期字符串),并进行相应的错误处理或默认值设置。
- 性能考量: 对于非常大的数据集,频繁的循环和类型转换可能会影响性能。在这种情况下,可以考虑在数据库查询阶段就进行部分数据格式化(如果数据库支持),或者优化PHP代码逻辑。
- 可读性与维护性: 尽管 switch 语句在此示例中有效,但如果字段转换逻辑变得复杂,可以考虑创建辅助函数或使用更具声明性的方式来处理数据转换。
总结
通过上述方法,我们成功地将CodeIgniter从数据库获取的关联数组数据,转换并重构为符合特定前端需求的嵌套JSON数组格式。这强调了在API开发中,对数据进行预处理和类型转换的重要性,以确保后端输出与前端消费接口之间的数据契合度。理解并掌握这种数据转换技巧,能让开发者在构建灵活且健壮的Web服务时更加得心应手。
终于介绍完啦!小伙伴们,这篇关于《CodeIgniter自定义JSON数组输出教程》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
251 收藏
-
186 收藏
-
336 收藏
-
448 收藏
-
488 收藏
-
282 收藏
-
162 收藏
-
129 收藏
-
323 收藏
-
313 收藏
-
267 收藏
-
100 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习