ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
PHPでオブジェクトを配列に変換するには、単純な変換なら(array)キャストかget_object_vars()、ネストしたオブジェクトまで丸ごと配列化したいならjson_decode(json_encode($obj), true)を使います。本稿では3つの方法それぞれの挙動と落とし穴、用途別の使い分けを、最小コードとともに解説します。
| この記事の要点 |
|---|
|
主な変換方法の一覧
PHPには標準で複数の変換手段があります。まず全体像を把握しておきましょう。
- 方法①
(array)キャスト … 関数不要・最速。すべてのプロパティを拾うが、private/protectedのキー名が特殊になる。 - 方法②
get_object_vars()… アクセス可能なプロパティだけをクリーンに取得。 - 方法③
json_decode(json_encode($obj), true)… ネスト構造ごと配列化したいときの定番。
それぞれ詳しく見ていきます。
方法① (array)キャストで変換する
もっとも手軽なのは型キャストです。オブジェクトの前に(array)を付けるだけで配列になります。
|
<?php |
publicプロパティだけのクラスなら、これで期待どおりの連想配列が得られます。
注意:private/protectedプロパティのキー名が特殊になる
(array)キャストはprivateやprotectedのプロパティも配列に含めますが、そのキー名に不可視の制御文字(ヌルバイト \0)が付与されるという独特の仕様があります。具体的には次のようになります。
- privateプロパティ → キーが
\0クラス名\0プロパティ名になる - protectedプロパティ → キーが
\0*\0プロパティ名になる(*はアスタリスク1文字) - publicプロパティ → キーはプロパティ名そのまま
|
<?php |
このヌルバイトは画面上では見えませんが文字列の一部としてキーに含まれているため、$array['name'] のように普通の名前ではアクセスできません。echoでは消えて見えるのにキー比較が一致しない、という分かりにくいバグの原因になります。private/protectedを持つクラスを安全に配列化したい場合は、後述の方法②・③を検討してください。
方法② get_object_vars()で変換する
get_object_vars()は、対象オブジェクトのアクセス可能なプロパティを連想配列で返す関数です。キー名はプロパティ名そのままで、ヌルバイトのような特殊文字は付きません。
|
<?php |
ポイントは「アクセス可能なプロパティ」という点です。呼び出す場所によって取得できる範囲が変わります。
- クラスの外から呼ぶと、
publicプロパティのみが返る(上記の例ではpinは含まれない)。 - クラスの内側(メソッド内)から
$thisを渡して呼ぶと、private・protectedも含めて返る。
|
<?php |
ヌルバイト問題を避けつつ、可視性を意図的にコントロールしたいときに最適な方法です。なお、この関数は1階層分のプロパティだけを配列化します。プロパティの値がさらにオブジェクトの場合、その値はオブジェクトのまま残ります(再帰しません)。
方法③ json_decode(json_encode())で変換する
ネストした構造ごと配列化したい場合の定番が、JSONを経由する方法です。json_encode()でいったんJSON文字列にし、json_decode()の第2引数にtrueを渡して連想配列としてデコードします。
|
<?php |
このとおり、入れ子になったAddressオブジェクトまで再帰的に配列へ変換されます。これが他の2方法にはない最大の利点です。一方で、JSONを経由するがゆえの注意点があります。
- publicプロパティしか変換されない …
json_encode()はデフォルトでprivate/protectedを無視するため、それらは結果に含まれない(JsonSerializableを実装すれば制御可能)。 - 型情報が失われる … すべてJSONで表現可能な型(文字列・数値・配列など)に変換される。リソース型などは扱えない。
- 非UTF-8データで失敗する …
json_encode()はUTF-8でない文字列があるとfalseを返し、変換が壊れることがある。 - 2回の変換コストがかかる … 大量データでは(array)キャストより遅い。
3つの方法の比較
用途別に整理すると次のとおりです。private/protectedを含み、かつ最も安全に扱える観点では用途に応じた選択になりますが、一般的なDTOの変換では推奨行の方法が無難です。
| 方法 | 変換の深さ | 対象の可視性 | キー名 | 主な用途 |
|---|---|---|---|---|
(array) キャスト |
浅い(1階層) | public/protected/private すべて | private/protectedに\0が付く |
publicのみのクラスを高速変換 |
get_object_vars() |
浅い(1階層) | 呼び出し位置で変化(外=public) | プロパティ名そのまま(クリーン) | 可視性を制御した安全な変換 |
json_decode(json_encode()) |
深い(再帰) | publicのみ | プロパティ名そのまま | ネスト構造ごと配列化 |
逆方向:配列をオブジェクトに変換する
反対に、配列をオブジェクトへ変換したい場合は(object)キャストが使えます。結果はstdClassのインスタンスになり、各キーがプロパティになります。
|
<?php |
ネストした配列まで再帰的にオブジェクト化したい場合は、こちらもjson_decode(json_encode($array))(第2引数を省略、またはfalse)を使うと、入れ子の配列までstdClassに変換できます。
落とし穴まとめ
| つまずきやすいポイント |
|---|
|
よくある質問(FAQ)
Q1.結局どの方法を使えばいいですか?
プロパティがpublicだけのシンプルなクラスなら(array)キャストが最速で十分です。private/protectedを含み、キー名をきれいに保ちたいならget_object_vars()。オブジェクトが入れ子になっていて全体を配列にしたいならjson_decode(json_encode($obj), true)を選びます。
Q2.(array)キャストで付くヌルバイトを取り除くには?
根本的には、private/protectedを正しく扱えるget_object_vars()(クラス内から呼ぶ)や、クラスにtoArray()メソッドを実装する方法に切り替えるのが安全です。すでにヌルバイト入りの配列を持っている場合は、キー文字列の\0区切りを分解して名前を取り出すこともできますが、最初から付かない方法を選ぶほうが確実です。
Q3.多次元(ネスト)のオブジェクトをまとめて配列化できますか?
はい。json_decode(json_encode($obj), true)なら、プロパティとして保持された別のオブジェクトや配列まで再帰的に配列へ変換されます。ただしpublicプロパティのみが対象で、型情報は失われる点に注意してください。private/protectedも含めて再帰変換したい場合は、各クラスに自前のtoArray()を実装するのが確実です。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
同階層のページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?