Because the protocol was originally designed to be simple and easy to use!
{"jsonrpc": "2.0", "method": "subtract", "params": [42, 23], "id": 1}
{"jsonrpc": "2.0", "result": 19, "id": 1}
{"jsonrpc": "2.0", "method": "subtract", "params": [23, 42], "id": 2}
{"jsonrpc": "2.0", "result": -19, "id": 2}
{"jsonrpc": "2.0", "method": "subtract", "params": {"subtrahend": 23, "minuend": 42}, "id": 3}
{"jsonrpc": "2.0", "result": 19, "id": 3}
{"jsonrpc": "2.0", "method": "subtract", "params": {"minuend": 42, "subtrahend": 23}, "id": 4}
{"jsonrpc": "2.0", "result": 19, "id": 4}
{"jsonrpc": "2.0", "method": "foobar", "id": 10}
{"jsonrpc": "2.0", "error": {"code": -32601, "message": "Procedure not found."}, "id": 10}
{"jsonrpc": "2.0", "method": "foobar", "params": "bar", "baz"}
{"jsonrpc": "2.0", "error": {"code": -32700, "message": "Parse error"}, "id": null}
{"jsonrpc": "2.0", "method": 1, "params": "bar"}
{"jsonrpc": "2.0", "error": {"code": -32600, "message": "Invalid JSON-RPC."}, "id": null}
{"jsonrpc": "2.0", "method": "subtract", "params": [42, 23], "id": 1}
{"jsonrpc": "2.0", "result": 19, "id": 1}
{"jsonrpc": "2.0", "method": "subtract", "params": [23, 42], "id": 2}
{"jsonrpc": "2.0", "result": -19, "id": 2}
{"jsonrpc": "2.0", "method": "subtract", "params": {"subtrahend": 23, "minuend": 42}, "id": 3}
{"jsonrpc": "2.0", "result": 19, "id": 3}
{"jsonrpc": "2.0", "method": "subtract", "params": {"minuend": 42, "subtrahend": 23}, "id": 4}
{"jsonrpc": "2.0", "result": 19, "id": 4}
{"jsonrpc": "2.0", "method": "foobar", "id": 10}
{"jsonrpc": "2.0", "error": {"code": -32601, "message": "Procedure not found."}, "id": 10}
{"jsonrpc": "2.0", "method": "foobar", "params": "bar", "baz"}
{"jsonrpc": "2.0", "error": {"code": -32700, "message": "Parse error"}, "id": null}
{"jsonrpc": "2.0", "method": 1, "params": "bar"}
{"jsonrpc": "2.0", "error": {"code": -32600, "message": "Invalid JSON-RPC."}, "id": null}
Sajya is the most popular open-source package for Laravel that makes it easy to implement the JSON-RPC 2.0 server specification including validation of parameters, support for batch and notification requests, and more.
Request and response format is unified and easy to use, allowing even beginners to work.
Use any transport you prefer, including HTTP
, WebSocket
, Server Sent Events
, or others.
Learn more about Specification.
{
"jsonrpc": "2.0",
"method": "subtract",
"params": {
"subtrahend": 23,
"minuend": 42
},
"id": 3
}
<-- Response
{
"jsonrpc": "2.0",
"result": 19,
"id": 3
}
Ability to send several requests in one API call. This helps reduce network costs and speed up your application.
Learn more about batch requests.
Send requests that do not need to be answered. Customers won't have to wait for the request to actually be fulfilled.
Learn more about notifications requests.
Build the API to your React, Vue.js and Angular web apps.
Communication from your native Android and iOS apps.
Something electronic on Rust, Go, C, Java? No problem at all.
namespace App\Http\Procedures;
use App\Models\User;
use Sajya\Server\Procedure;
class UserProcedure extends Procedure
{
public function update(User $user)
{
// ...
}
}
Bind values of query parameters to various objects such as Eloquent
models, Enums
and others, which allows you to work with data in your project quickly and conveniently.
Learn more about Binding.
Automatically validates incoming requests to ensure they meet your specifications. You can also customize the error messages that are returned if the validation fails.
Learn more about request validation.