Utility Payments Java Quickstart

Raphael Ugwu

Raphael Ugwu

2 min

This quick start will guide you through integrating Reloadly’s Utility Payments API using a Java application. Prerequisites needed for this guide are:

  • The reader should have a decent understanding of Java
  • A Reloadly account. If you don’t already have one, follow the registration procedure.
  • Next, you need to have funds in your test wallet. When you sign up, a certain amount of funds are automatically added to your test wallet. You can fund your live wallet by following the steps in the Wallet section.
  • Sign in to retrieve your client_id and client_secret keys for test mode. You can get both keys by toggling from live to test mode on the sidebar and navigating to Developers > API settings

Get an access token

Reloadly issues access tokens (also called bearer tokens) that are used to authorize API requests. Using the right parameters, make a request to Reloadly’s authorization URL to obtain the appropriate access token.

You can get a test access token by making a request in your Java application like this

import org.apache.http.util.EntityUtils;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.entity.StringEntity;
import org.json.JSONObject;
import org.json.JSONArray;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.entity.mime.MultipartEntity;
import org.apache.http.entity.mime.content.StringBody;

public class App {
  public static void main(String[] args ) throws java.io.IOException {
    HttpClient httpClient = HttpClientBuilder.create().build();

    HttpPost request = new HttpPost("https://auth.reloadly.com/oauth/token");
    request.setHeader("Content-Type", "application/json");
    JSONObject payload = new JSONObject();
    payload.put("client_id", "qwcLzXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX");
    payload.put("client_secret", "7kscVxQZ32-XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX");
    payload.put("grant_type", "client_credentials");
    payload.put("audience", "https://utilities-sandbox.reloadly.com");
    request.setEntity(new StringEntity(payload.toString()));
    String response = EntityUtils.toString(httpClient.execute(request).getEntity());

    System.out.println(response);
  }
}

While production access tokens are valid for 60 days, test access tokens are only valid for 24 hours.

If your request is successful, you should get the following response.

{
    "access_token": "eyJraWQiOiI1N2JjZjNhNy01YmYwLTQ1M2QtODQ0Mi03ODhlMTA4OWI3MDIiLCJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiI2NzkzIiwiaXNzIjoiaHR0cHM6Ly9yZWxvYWRseS1zYW5kYm94LmF1dGgwLmNvbS8iLCJodHRwczovL3JlbG9hZGx5LmNvbS9zYW5kYm94Ijp0cnVlLCJodHRwczovL3JlbG9hZGx5LmNvbS9wcmVwYWlkVXNlcklkIjoiNjc5MyIsImd0eSI6ImNsaWVudC1jcmVkZW50aWFscyIsImF1ZCI6Imh0dHBzOi8vdG9wdXBzLWhzMjU2LXNhbmRib3gucmVsb2FkbHkuY29tIiwibmJmIjoxNjU0MDgzNjY3LCJhenAiOiI2NzkzIiwic2NvcGUiOiJzZW5kLXRvcHVwcyByZWFkLW9wZXJhdG9ycyByZWFkLXByb21vdGlvbnMgcmVhZC10b3B1cHMtaGlzdG9yeSByZWFkLXByZXBhaWQtYmFsYW5jZSByZWFkLXByZXBhaWQtY29tbWlzc2lvbnMiLCJleHAiOjE2NTQxNzAwNjcsImh0dHBzOi8vcmVsb2FkbHkuY29tL2p0aSI6IjYwMTY4ODNiLWYxYTgtNGJhMy1hNmM3LWIwNjBkNDRmN2EyMCIsImlhdCI6MTY1NDA4MzY2NywianRpIjoiZGUwNzRlM2QtM2JkYi00N2ExLTkzNDktZTk1YmZiNjZlNGVmIn0.ZXUzCYbCCTzpDMr5hP7YvgWYqniy9kBY0Y5vWS8wRrA",
    "scope": "developer",
    "expires_in": 86400,
    "token_type": "Bearer"
}

Pay a utility bill

Now that you have an access token, you can pay a utility bill with the Utility Payments API. You can find details of the bill you want to pay by Getting all billers available on Reloadly’s platform.

In the example below, we will show how making a bill payment works by paying for an electricity bill for a Nigerian electricity payment provider.

import org.apache.http.util.EntityUtils;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.entity.StringEntity;
import org.json.JSONObject;
import org.json.JSONArray;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.entity.mime.MultipartEntity;
import org.apache.http.entity.mime.content.StringBody;

public class App {
  public static void main(String[] args ) throws java.io.IOException {
    HttpClient httpClient = HttpClientBuilder.create().build();

    HttpPost request = new HttpPost("https://utilities-sandbox.reloadly.com/pay");
    request.setHeader("Content-Type", "application/json");
    request.setHeader("Authorization", "Bearer <YOUR_TOKEN_HERE>");
    JSONObject payload = new JSONObject();
    payload.put("subscriberAccountNumber", 4223568280);
    payload.put("amount", 1000);
    payload.put("billerId", 5);
    payload.put("useLocalAmount", false);
    payload.put("referenceId", "april-electricity-bill");
    request.setEntity(new StringEntity(payload.toString()));
    String response = EntityUtils.toString(httpClient.execute(request).getEntity());

    System.out.println(response);
  }
}

If your request is successful, you should receive a response from Reloadly

{
    "id": 69,
    "status": "PROCESSING",
    "referenceId": null,
    "code": "PAYMENT_PROCESSING_IN_PROGRESS",
    "message": "The payment is being processed, status will be updated when biller processes the payment.",
    "submittedAt": "2022-06-10 16:46:32",
    "finalStatusAvailabilityAt": "2022-06-11 16:46:31"
}

If you made it to this point, you have successfully made your first utility payment in a Java application.

This might also interest you:

3 min
Micro-rewarding is transforming how businesses, educators, and organizations engage with their audiences. By offering small, frequent incentives, this innovative approach enhances loyalty, drives behavior change, and keeps people motivated. Learn how micro-rewarding can create big impacts with minimal costs.

Content by developers to developers.

Subscribe to The Monthly Reload for Developers and start receiving all the developers’ updates.

The Monthly Reload: the newsletter for you

Subscribe to our Newsletter and don’t miss any news about our industry and products.

It’s time to build, make your first API call today