top of page
Writer's pictureShreya Das

Different Ways to Create API Request Payload

What is API Payload?

In API(Application Programming Interface), a ‘Payload’ refers to the dataset which is sent within request or received through a response. When we request data from a server, the data we send along with the request or the data we receive in response is the payload. It's like the content of a letter we're sending or receiving.The payload can be sent or received in various formats, including JSON (JavaScript Object Notation). Usually, the payload is denoted using the “{}” in a query string.




Types of API Payload:


Key Components of API Request:

An API request consists of several components that convey specific information to the server. Below are the components which help to fulfill the requirements for both client and server.


  • API EndPoints : The API endpoint is the resource URL that we want to access.

  • HTTP methods: HTTP methods include below

    • GET: This is read only value by this method we can get the resource's data

    • POST: With this method we are creating a new resource in the server

    • PUT: With this method we can update the resource with new data in the server

    • Delete: With this method we can delete the resource from server

  • Request Headers: Header information which are sent with API request, below are few examples

    • Authorization which is access token to access the endpoints

    • The expected response format (application/json to request JSON data)

  • Request Payload: Request payload is basically the data set which we are sending in to the server in the request body to get the response

  • Query Parameters: There are few additional data need to sent with the URL to modify the request or filter the response.

  • Response Headers: Response headers includes few additional information about the server’s response

  • Response body: The response payload body contains the data returned by the server in response to the API request. Response payload formats include JSON, XML, HTML, or plain text.

    • 200: When the request was successful, the server returned the requested data as 200 OK

    • 204: The request was successful, but there is no data to return. Then it shows as 204 NoContent. It is used for successful DELETE requests.

    • 400: The server cannot process the request due to a client side error. Then it display 400 Bad Request

    • 500: The server encountered an error while processing the request, indicating a server-side issue and gives Internal Server Error


What is Request Payload?

The request payload is the data set in the request body. The data sent to the server for methods like POST, PUT, or PATCH.


JSON payload format can be different types:

  • As a simple JSON format

  • As a Complex Nested JSON format


** This article gives a detailed overview to create Simple JSON Request payload body as well as Complex Nested JSON Request payload body.



[Creation of a Simple JSON Request Payload]


Below examples are shown to share 4 different ways of Simple JSON Request Payload creation:

  • Using HashMap

  • Using Org.JSON

  • Using POJO

  • Using External JSON file


Simple JSON Request Payload:

{

"name": "Jhon",

"job": "Associate"

}

In this above example, we're sending the payload object as JSON in the body of a POST request to an API endpoint for creating user with the Job role.


Scenario: Create User (with valid endpoint and valid data. http method used as POST)

Step1: Create a Maven Project

Step 2: Add all required dependencies in POM.xml file

Step3: Create Feature File for create user scenario under src/test/resources

Step4: Create EndPoint enum class to maintain the endpoint details under src/test/java/utilities

Step5: Under src/test/java/stepDefinitions create stepdefinition class for createUser

Step6: Create TestRunner Under src/test/java/cucumber.Options


Using HashMap:

Follow the below process to create the request payload:

  • @Given section we have to create the request payload using HashMap key value pair method

    • First need to create the request body as per the JSON format using HashMap put operation

    • Now create the request, using body (created above), header(contentType) & query-parameter information and store into a request variable

  • @When section we have to pass the endpoint and httpmethod to the request payload and need to store into a response variable ·      

  • @Then section after getting the response we can validate the status code


Using Org.JSON:

Follow the below process to create the request payload:

  • @Given section we have to create the request payload using org.JSON key value pair method

    • First, we have to add JSON org library in pom.xml file


    • Then need to create the request body as per the JSON format using JSONObject put operation and also need to convert the JSONObJect data to string

    • After the above create the request, using body (created above), header(contentType) & query-parameter information and store into a request variable

  •   @When section we have to pass the endpoint and httpmethod to the request payload and need to store into a response variable ·      

  • @Then section after getting the response we can validate the status code


Using POJO(Plain old java object class ):

Follow the below process to create the request payload:

  • Create createuser POJO class under src/test/java/POJO

  • @Given section we have to create first the object of the above POJO class

    • Then create the request payload body using setter method of POJO class

    • After the above create the request, using body (created above), header(contentType) & query-parameter information and store into a request variable

  • @When section we have to pass the endpoint and httpmethod to the request payload and need to store into a response variable

  • @Then section after getting the response we can validate the status code

External JSON File:

Follow the below process to create the request payload:

  • Add the external JSON file(payloadbody.json) in your framework

{

    "name": "Jhon",

     "job": "Associate"

}

  • @Given section we have to create the request payload from provided external JSON file

    • First, we have to open the JSON file using java File type object giving the file location as parameter

    • Then we have to read the file using two classes passing the file object

      • Java FileReader

      • JSONTokener from org.json

    • Using JSONTokener we have to extract the data in a JSON format and for that we have to use JSONObject class

    • After getting the data in a JSON format now we can pass data in a request body

    • Then create the request, using body (created above), header(contentType) & query-parameter information and store into a request variable ·      

  • @When section we have to pass the endpoint and httpmethod to the request payload and need to store into a response variable ·      

  • @Then section after getting the response we can validate the status code


[Creation of a Complex Nested JSON Request Payload]


We can create complex nested JSON payload using all 4 different ways as like shown in simple JSON Request payload creation.


Below example to show one way of Complex Nested JSON Request Payload creation:

  • Using POJO


Complex Nested JSON Request Payload:

{

  "id": 0,

  "category": {

     "id": 0,

    "name": "string"

  },

  "name": "doggie",

  "photoUrls": [

    "string"

  ],

  "tags": [

     {

       "id": 0,

       "name": "string"

     }

  ],

  "status": "available"

}


In this above example, we're sending the payload object as JSON in the body of a POST request to an API endpoint for creating Pet information in the Store.


In the above JSON request body, it has:

  •   Nested JSON [category is the nested JSON]

  •   Array in JSON [photoUrls is simple Array]

  •   Nested JSON under Array [tags is the JSON under Array]


To create the above JSON payload, we have to create below POJO classes:

  •  One Parent POJO class

  • Two child POJO classes [category, tags]

  • For simple Array mention return type as List of String

  • For JSON under array mention return type as List of the POJO class of that JSON


Parent POJO class:


Child POJO classes:

Below is the feature file for the complex JSON payload creation


Below are the steps need to mention in the step definition:

  • @Given section we have to create first the object of the above POJO classes for both parent & child POJO classes

    • Then create the request payload body using setter method

    • Use ArrayList to add the data into the array

    • After the above create the request, using body (created above), header(contentType) & query-parameter information and store into a request variable

  • @When section we have to pass the endpoint and httpmethod to the request payload and need to store into a response variable

  • @Then section after getting the response we can validate the status code

Below is the response payload:

Body:

{

    "id": 0,

     "category": {

        "id": 55,

        "name": "PetCategory"

  },

     "name": "MyDog",

    "photoUrls": [

        "DogPhoto"

    ],

    "tags": [

        {

            "id": 66,

            "name": "DogTags"

        }

    ],

    "status": "Available"

}


265 views

Recent Posts

See All
bottom of page