HCODX/JSON to PHP
100% browser-based · Nested types · PHP-idiomatic naming

JSON to PHP

Paste JSON and get a PHP 7.4+ class with typed properties and a constructor that assigns every field. Ready for your Laravel, Symfony, or vanilla PHP project.

JSON input
PHP output
Generator options
Input size
0 B
Output size
0 B
Output lines
0
Status
Ready
Example

JSON in, PHP out

Paste a typical JSON payload and the tool emits idiomatic PHP types — nested objects each become their own type.

JSON
{
  "id": 1,
  "name": "Alice",
  "isActive": true
}
PHP
Generated PHP appears here.
Use cases

What you'll use this for

Skip the boilerplate. Whenever you have an example JSON payload and need typed code on the other side, paste and generate.

API client models

Generate DTOs for a third-party REST API from a sample response.

Database row types

Model JSON columns or document-store records as native PHP types.

Mobile + backend parity

Keep client and server types in sync — both generated from the same JSON.

Fixtures and tests

Turn fixture JSON into typed code for unit tests and integration mocks.

Step by step

How to convert JSON to PHP

1

Paste your JSON

Drop a valid JSON object into the left editor. Arrays at the root work too — the first element is sampled.

2

Pick a class name

Default is Root. Use anything PascalCase that fits your domain.

3

Click Generate

Or leave auto-generate on for live updates as you edit JSON. Runs entirely in your browser.

4

Copy or download

Copy to clipboard or save as a .php file ready to drop into your project.

FAQ

Frequently asked questions

PHP 7.4+ for typed properties. PHP 8 adds mixed and other niceties used here.

Yes. Each nested JSON object becomes its own class with PascalCase naming and a typed constructor.

Field names are converted to camelCase on the PHP side. Map back to wire-format JSON in your serializer.

Yes. Completely free, no signup, no limits. Runs entirely in your browser.

About

About JSON to PHP

This tool converts a sample JSON payload into idiomatic PHP code. Every nested object is recursively turned into its own type with PascalCase naming, while keys are converted to the conventional case for the language.

Type inference

  • Strings stay strings.
  • Integers use the language's widest safe integer type (e.g. long, Int, i64).
  • Decimals become double-precision floats.
  • Arrays become a generic list keyed off the first element's type.
  • Booleans map to the native boolean type.
  • Nested objects recurse into their own type definitions.

Privacy

  • All conversion happens locally in your browser.
  • No JSON ever leaves your device.
  • No signup, no tracking of payloads.
Related

Related tools