CakePHPです。
PHP Version 7.2.34(localhostにアクセスして頭に表示されている)
目的は、モデルから取り出したデータをjsonにしてかえそうとしています。
DBを個別に取り出しているのは、まだ間もないためModelの操作が分からないためです。
そこで各テーブルに個別にアクセスして、取り出したデータを以下の「本来取り出したい形」にあるjsonの形にしたいのですが、方法が分かりませんでした。
入れ子に出来るはずだと思っています。
この方法を教えて頂きたいです。
よろしくお願いいたします。
本来作りたい形
json
1{ 2 "userdata": { 3 "id": 1, 4 "name": "test_user", 5 "units": [], 6 "items": [{ 7 "id": 1, 8 "user_id": 1, 9 "unit_id": 1, 10 "exp": 0, 11 "level": 1, 12 "equipment1": 0, 13 "equipment2": 0, 14 "equipment3": 0, 15 "equipment4": 0 16 }] 17 }, 18 19}
調べながら、試したコードは3つほど以下のようになります。
● 一つ目
php
1$id = 1; 2$query = TableRegistry::get('userdata'); 3$user = $query->find()->where(['id' => $id])->first(); 4$query_useritem = TableRegistry::get('useritem'); 5$items = $query_useritem->find()->where(['user_id' => $id]); 6$query_userunit = TableRegistry::get('userunit'); 7$units = $query_userunit->find()->where(['user_id' => $id]); 8 9//連想配列が繋がるだけでした。 10$ret = array($user,'units'=>$items,'items'=>$units); 11echo json_encode($ret);
出力結果
json
1{ 2 "0": { 3 "id": 1, 4 "name": "test_user" 5 }, 6 "units": [], 7 "items": [ 8 { 9 "id": 1, 10 "user_id": 1, 11 "unit_id": 1, 12 "exp": 0, 13 "level": 1, 14 "equipment1": 0, 15 "equipment2": 0, 16 "equipment3": 0, 17 "equipment4": 0 18 } 19 ] 20}
● 2つ目
php
1$id = 1; 2$query = TableRegistry::get('userdata'); 3$user = $query->find()->where(['id' => $id])->first(); 4$query_useritem = TableRegistry::get('useritem'); 5$items = $query_useritem->find()->where(['user_id' => $id]); 6$query_userunit = TableRegistry::get('userunit'); 7$units = $query_userunit->find()->where(['user_id' => $id]); 8 9// array_merge()を使った場合 10$user = array('userdata'=>$user); 11$user = array_merge($user, array('units'=>$units,'items'=>$items)); 12echo json_encode($user);
出力結果
json
1{ 2 "userdata": { 3 "id": 1, 4 "name": "test_user" 5 }, 6 "units": [ 7 { 8 "id": 1, 9 "user_id": 1, 10 "unit_id": 1, 11 "exp": 0, 12 "level": 1, 13 "equipment1": 0, 14 "equipment2": 0, 15 "equipment3": 0, 16 "equipment4": 0 17 } 18 ], 19 "items": [] 20}
● 3つ目
php
1$id = 1; 2$query = TableRegistry::get('userdata'); 3$user = $query->find()->where(['id' => $id])->first(); 4$query_useritem = TableRegistry::get('useritem'); 5$items = $query_useritem->find()->where(['user_id' => $id]); 6$query_userunit = TableRegistry::get('userunit'); 7$units = $query_userunit->find()->where(['user_id' => $id]); 8$user = array('userdata'=>$user); 9 10//一つのarrayにいれてみる。 11$array[] = $user; 12$array[] = $units; 13$array[] = $items; 14 15echo json_encode($array);
結果
json
1[ 2 { 3 "userdata": { 4 "id": 1, 5 "name": "test_user" 6 } 7 }, 8 [ 9 { 10 "id": 1, 11 "user_id": 1, 12 "unit_id": 1, 13 "exp": 0, 14 "level": 1, 15 "equipment1": 0, 16 "equipment2": 0, 17 "equipment3": 0, 18 "equipment4": 0 19 } 20 ], 21 [] 22]
ーー追記ーー
以下より
修正を試したところ「+=」演算子がの所でエラーになってしまいました
バージョンの問題かと思ったんですが、以下該当の行のエラーですが、
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
1$id = 1; 2$query = TableRegistry::get('userdata'); 3$user = $query->find()->where(['id' => $id])->first(); 4$query_useritem = TableRegistry::get('useritem'); 5$items = $query_useritem->find()->where(['user_id' => $id]); 6$query_userunit = TableRegistry::get('userunit'); 7$units = $query_userunit->find()->where(['user_id' => $id]); 8 9$user["units"] += $units; 10$user["items"] += $items; 11echo 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 # ################################################################################
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/12/20 05:32
2021/12/20 05:41
2021/12/20 05:43
2021/12/20 05:48
2021/12/20 06:11 編集
2021/12/20 06:05
2021/12/20 06:17
2021/12/20 06:17
2021/12/20 06:23
2021/12/20 06:24
2021/12/20 06:27 編集
2021/12/20 06:28
2021/12/20 06:29