dongqian3198 2014-02-17 23:32
浏览 28
已采纳

在CakePHP中自定义JSON输出

In CakePHP 2.4, what is the correct syntax to foreach through my data in order to customize the contents and structure of JSON output from my controller?

I currently have the following method, which creates a .json that directly mirrors Cake's internal array of all my posts:

public function points() {
$this->autoRender = false; // We don't render a view in this example
$this->Post->recursive = -1; //Don't return stuff we don't need

return json_encode($this->Post->find('all'));
}

This creates JSON that looks like this, with each post's data the child of its own Post object (prettified with carriage returns so you can read it):

[{"Post":{"id":"1",
          "user_id":"1",
          "organism_id":"0",
          "title":"Title Text",
          "lat":"44.54401744186992",
          "lng":"-68.26070404052734",
          "body":"Body Text",
          "created":"2014-01-19 07:13:29",
          "modified":"2014-01-19 07:13:29"}
 },
 {"Post":{"id":"2",
          "user_id":"1",
          "organism_id":"0",
          "title":"Title Text",
          "lat":"44.54401744186992",
          "lng":"-68.26070404052734",
          "body":"Body Text",
          "created":"2014-01-19 07:13:29",
          "modified":"2014-01-19 07:13:29"}
 }]

This is a problem, because (A) For performance reasons, I might not want to dump all the data for each post into the JSON, and (B) for output to Google Maps, I need to output each post's data as child objects of one Posts object, like so:

{"Posts":[
    {"id":"1",
    "user_id":"1",
    "organism_id":"0",
    "title":"Title Text",
    "lat":"44.54401744186992",
    "lng":"-68.26070404052734",
    "body":"Body Text",
    "created":"2014-01-19 07:13:29",
    "modified":"2014-01-19 07:13:29"
},
    {"id":"2",
    "user_id":"1",
    "organism_id":"0",
    "title":"Title Text",
    "lat":"44.54401744186992",
    "lng":"-68.26070404052734",
    "body":"Body Text",
    "created":"2014-01-19 07:13:29",
    "modified":"2014-01-19 07:13:29"}]}

I know I somehow need to foreach through the data and build an array. How does this work? foreach ($posts as $post): doesn't work inside the controller.

  • 写回答

3条回答 默认 最新

  • douyuan1049 2014-02-18 02:32
    关注

    I found the solution!

    In the controller:

    public function points() {
        $this->request->onlyAllow('ajax'); //Don't respond to non-AJAX requests
        $this->Post->recursive = -1; //don't return info from other controllers
        $this->set('posts', $this->Post->find('all'));
    }
    

    In /view/posts/json/points.ctp:

    foreach ($posts as $post) {
    $markers[] = array(
        'id' => $post['Post']['id'],
        'lat' => $post['Post']['lat'],
        'lng' => $post['Post']['lng']
        ); //make an array of the contents of each post I want to include
    
    }
    
    $data = array(
    'Posts' => $markers); //Make everything the child of a 'Posts' object
    
     echo json_encode($data); //Turn it into JSON!
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么