当前位置:首页 > 文章列表 > 文章 > php教程 > CodeIgniter自定义JSON数组输出教程

CodeIgniter自定义JSON数组输出教程

2025-11-04 11:21:33 0浏览 收藏

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

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编码并没有满足以下两点要求:

  1. 数据结构变化: 期望的是一个二维数组,内部数组只包含值,而不是键值对。
  2. 数据类型转换: 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);
    }
}

代码解析:

  1. $temp = [];: 初始化一个空数组,用于存放最终重构的数据。
  2. 外层 foreach ($invoices as $key1 => $value1): 遍历从模型中获取的每一条发票记录。$value1 在这里代表单条发票的关联数组,例如 ['date_issued' => '2021-03-01', 'grand_total' => '972.948']。
  3. $row_data = [];: 在处理每条发票记录之前,初始化一个空数组来存储该记录转换后的 [时间戳, 金额] 对。
  4. 内层 foreach ($value1 as $key2 => $value2): 遍历当前发票记录的各个字段。
  5. switch ($key2): 根据字段名进行条件判断和处理。
    • case 'date_issued': 使用 strtotime($value2) 将日期字符串转换为Unix时间戳(秒)。由于前端可能需要毫秒级时间戳,这里乘以 1000。
    • case 'grand_total': 使用 floatval($value2) 将字符串形式的总金额转换为浮点数。
    • default: 对于其他不需要包含在最终JSON中的字段,可以忽略。
  6. $row_data[] = ...: 将转换后的值依次添加到 $row_data 数组中,这样就形成了 [时间戳, 金额] 的结构。
  7. $temp[] = $row_data;: 将处理好的 $row_data (即 [时间戳, 金额] 数组)添加到 $temp 数组中,从而构建出 [[时间戳1, 金额1], [时间戳2, 金额2]] 的二维数组结构。
  8. $response['price'] = $temp;: 将重构后的 $temp 数组赋值给 $response 的 price 键。
  9. header('Content-Type: application/json');: 确保浏览器或客户端正确解析响应内容为JSON。
  10. 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学习网公众号也会发布文章相关知识,快来关注吧!

多分辨率适配方案,HTML全屏兼容技巧多分辨率适配方案,HTML全屏兼容技巧
上一篇
多分辨率适配方案,HTML全屏兼容技巧
百度地图路线错误怎么处理?自动纠偏技巧
下一篇
百度地图路线错误怎么处理?自动纠偏技巧
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3179次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3390次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3419次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4525次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3798次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码