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 # ################################################################################
まだ回答がついていません
会員登録して回答してみよう