質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

解決済

[PHP] 連想配列をjson形式に変換する時の事ですが、形式を入れ子にする方法が分かりませんでした。連想配列を入れ子にするのだと思いましたがみつからずです。

rocket
rocket

総合スコア41

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

1回答

0評価

0クリップ

343閲覧

投稿2021/12/20 04:03

編集2021/12/20 05:34

CakePHPです。
PHP Version 7.2.34(localhostにアクセスして頭に表示されている)

目的は、モデルから取り出したデータをjsonにしてかえそうとしています。

DBを個別に取り出しているのは、まだ間もないためModelの操作が分からないためです。
そこで各テーブルに個別にアクセスして、取り出したデータを以下の「本来取り出したい形」にあるjsonの形にしたいのですが、方法が分かりませんでした。
入れ子に出来るはずだと思っています。
この方法を教えて頂きたいです。

よろしくお願いいたします。

本来作りたい形

json

{ "userdata": { "id": 1, "name": "test_user", "units": [], "items": [{ "id": 1, "user_id": 1, "unit_id": 1, "exp": 0, "level": 1, "equipment1": 0, "equipment2": 0, "equipment3": 0, "equipment4": 0 }] }, }

調べながら、試したコードは3つほど以下のようになります。

● 一つ目

php

$id = 1; $query = TableRegistry::get('userdata'); $user = $query->find()->where(['id' => $id])->first(); $query_useritem = TableRegistry::get('useritem'); $items = $query_useritem->find()->where(['user_id' => $id]); $query_userunit = TableRegistry::get('userunit'); $units = $query_userunit->find()->where(['user_id' => $id]); //連想配列が繋がるだけでした。 $ret = array($user,'units'=>$items,'items'=>$units); echo json_encode($ret);

出力結果

json

{ "0": { "id": 1, "name": "test_user" }, "units": [], "items": [ { "id": 1, "user_id": 1, "unit_id": 1, "exp": 0, "level": 1, "equipment1": 0, "equipment2": 0, "equipment3": 0, "equipment4": 0 } ] }

● 2つ目

php

$id = 1; $query = TableRegistry::get('userdata'); $user = $query->find()->where(['id' => $id])->first(); $query_useritem = TableRegistry::get('useritem'); $items = $query_useritem->find()->where(['user_id' => $id]); $query_userunit = TableRegistry::get('userunit'); $units = $query_userunit->find()->where(['user_id' => $id]); // array_merge()を使った場合 $user = array('userdata'=>$user); $user = array_merge($user, array('units'=>$units,'items'=>$items)); echo json_encode($user);

出力結果

json

{ "userdata": { "id": 1, "name": "test_user" }, "units": [ { "id": 1, "user_id": 1, "unit_id": 1, "exp": 0, "level": 1, "equipment1": 0, "equipment2": 0, "equipment3": 0, "equipment4": 0 } ], "items": [] }

● 3つ目

php

$id = 1; $query = TableRegistry::get('userdata'); $user = $query->find()->where(['id' => $id])->first(); $query_useritem = TableRegistry::get('useritem'); $items = $query_useritem->find()->where(['user_id' => $id]); $query_userunit = TableRegistry::get('userunit'); $units = $query_userunit->find()->where(['user_id' => $id]); $user = array('userdata'=>$user); //一つのarrayにいれてみる。 $array[] = $user; $array[] = $units; $array[] = $items; echo json_encode($array);

結果

json

[ { "userdata": { "id": 1, "name": "test_user" } }, [ { "id": 1, "user_id": 1, "unit_id": 1, "exp": 0, "level": 1, "equipment1": 0, "equipment2": 0, "equipment3": 0, "equipment4": 0 } ], [] ]

ーー追記ーー

以下より

修正を試したところ「+=」演算子がの所でエラーになってしまいました
バージョンの問題かと思ったんですが、以下該当の行のエラーですが、

Notice (8): Object of class Cake\ORM\Query could not be converted to int [APP/Controller\UserController.php, line 27]

$user["units"] += $units;

ここで int に変換しようとしているようで、どちらも連想配列だと思うのですが。
違うのでしょうか。


修正したコード

php

$id = 1; $query = TableRegistry::get('userdata'); $user = $query->find()->where(['id' => $id])->first(); $query_useritem = TableRegistry::get('useritem'); $items = $query_useritem->find()->where(['user_id' => $id]); $query_userunit = TableRegistry::get('userunit'); $units = $query_userunit->find()->where(['user_id' => $id]); $user["units"] += $units; $user["items"] += $items; echo json_encode($user);


「Unsupported operand types」が発生しています。

Notice (8): Object of class Cake\ORM\Query could not be converted to int [APP/Controller\UserController.php, line 27] Notice (8): Object of class Cake\ORM\Query could not be converted to int [APP/Controller\UserController.php, line 28]{"id":1,"name":"test_user","rank":1,"exp":0,"lastlogin":"2021-12-04T18:11:24+00:00","created":"2021-12-04T18:11:24+00:00","units":1,"items":1} Warning (512): Unable to emit headers. Headers sent in file=D:\_TechStadium20211101\ts\90_FinalProject\20_ServerProject\htdocs\PriconneR\vendor\cakephp\cakephp\src\Error\Debugger.php line=853 [CORE\src\Http\ResponseEmitter.php, line 48] Warning (2): Cannot modify header information - headers already sent by (output started at D:\_TechStadium20211101\ts\90_FinalProject\20_ServerProject\htdocs\PriconneR\vendor\cakephp\cakephp\src\Error\Debugger.php:853) [CORE\src\Http\ResponseEmitter.php, line 148] Warning (2): Cannot modify header information - headers already sent by (output started at D:\_TechStadium20211101\ts\90_FinalProject\20_ServerProject\htdocs\PriconneR\vendor\cakephp\cakephp\src\Error\Debugger.php:853) [CORE\src\Http\ResponseEmitter.php, line 181] Warning (2): Cannot modify header information - headers already sent by (output started at D:\_TechStadium20211101\ts\90_FinalProject\20_ServerProject\htdocs\PriconneR\vendor\cakephp\cakephp\src\Error\Debugger.php:853) [CORE\src\Http\ResponseEmitter.php, line 181] Unsupported operand types Error


バージョン確認してみました。
PHP Version 7.2.34
CakePHP

$ php bin/cake ################################################################################ # # Cake is a shell script for invoking CakePHP shell commands # # CakePHP(tm) : Rapid Development Framework (https://cakephp.org) # Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) # # Licensed under The MIT License # For full copyright and license information, please see the LICENSE.txt # Redistributions of files must retain the above copyright notice. # # @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org) # @link https://cakephp.org CakePHP(tm) Project # @since 1.2.0 # @license https://opensource.org/licenses/mit-license.php MIT License # ################################################################################

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。