Zaap makes it super easy for you to write a PHP REST API.
v1.2
: 2021-09-27
Here's what you do:
Put a copy of the API template file (ZaapReceiver.php
) on your server. Make changes to it according to this README.
Need to make requests to your fresh API from PHP? Check out ZaapRemote.
Here's a list of the different variables in the file and what they contain.
Example request: GET http://example.com/ZaapReceiver.php/getUser/byID/?id=1234&file=temp
variable | what it's for |
---|---|
$method |
Contains the HTTP method by which the request was received (GET , POST , DELETE , PUT , etc). In the example, it contains the string " GET ". |
$endpoint |
Contains the entire request endpoint as a string. In the example, that's " getUser/byID ". |
$endpointArray |
Contains the endpoint in an array, with each value of the array corresponding to a segment of the endpoint. In the example, that's ["getUser","byID"] . |
$params |
Contains the parameters and values from the query string in an array. The same as $_GET . In the example, that's {"id":"1234","file":"temp"} . |
$input |
An array that contains the JSON-decoded input received in the request body. Mostly useful for POST and PUT, although they can be used with GET and DELETE too. |
$output |
An array that contains the data that is to be returned to whoever is making the request. |
ZaapReceiver.php
accepts four kinds of HTTP requests: GET
, POST
, PUT
and DELETE
. It accepts JSON-encoded payloads in the request's body.
You can rename the file if you wish, of course.
Right off the bat, you can leave the first few lines of the script as is, and jump to the switch satatement.
There's a case for each request method, and within each there's a second switch statement for the first endpoint segment. Use this to map endpoints to functions. For example, the endpoint getUser
can be mapped to readUser()
, or whatever.
If you're not planning on supporting certain HTTP methods (such as PUT or DELETE), simply delete them from the switch statement to simplify your code.
In the file, getOne()
is a simple example that demonstrates how you should write your functions.
- Use the data in
$input
,$params
,$endpoint
and$endpointData
to do whatever it is that the function needs to do. - If you find that the request is invalid, then simply call
errorInvalidRequest()
, otherwise: - Store whatever data needs to be returned to the client in
$output
. - If an error occurs, then change
$output["error"]
to1
to inform the client that an error occured, and store an error message in$output["errorMessage"]
. - If no error occurs, then store a success return code in
$output["returnCode"]
to inform the client of the same. - Call
printOutput()
, to which you should pass an appropriate HTTP status code as an argument. If none is passed, then200
(OK) is used by default.
This function will JSON-encode$output
and print it for the client. - You can now exit the script.
- Congrats, your REST API is now ready!
Here are a few of the recommended elements for $output
. Obviously you have to add others too, to return relevant data.
element | what it's for |
---|---|
$output["error"] |
Bool. Indicates whether or not an error occured. 0 by default. Change to 1 if an error occurs. |
$output["errorCode"] |
Use this to return an error code if an error occurs. NULL by default. |
$output["errorMessage"] |
Use this to return an error message if an error occurs. NULL by default. |
$output["returnCode"] |
Use this to return a code upon execution of the relevant code. |
Documentation updated: 2021-12-31
.