# Use the Java SDK > Learn how to install and use the Java SDK to develop apps {/* vale Payabli.We = NO */} {/* First person rule off for Quickstart */} Payabli offers a Software Development Kit (SDK) for the Java programming language. The Java SDK can be installed in your projects to support app development and provide type safety when calling Payabli's APIs. Most development environments can use the SDK to generate code suggestions and inline documentation. See the [sdk-java](https://github.com/payabli/sdk-java) package for more information. ## Dependencies Before you begin, make sure you have the following installed on your machine: * [Java JDK](https://www.oracle.com/java/technologies/javase-downloads.html) 11+ * [Maven](https://maven.apache.org/install.html) 3.6+ * [git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) ## Use the SDK This section shows you how to install and use the Payabli SDK in a new Java project. The example code shows how to use the SDK to make a transaction with the `moneyIn().getpaid` method. The `moneyIn().getpaid` method calls the [MoneyIn/getpaid](/developers/api-reference/moneyin/make-a-transaction) endpoint. See the [SDK reference](https://github.com/payabli/sdk-java/blob/main/reference.md) for a full list of methods. Method names in the SDK correspond to endpoint names in the API reference. For example: the `notification().addNotification` method calls the [POST Notification](/developers/api-reference/notification/add-notification) endpoint. Open your terminal and run the following commands to create a new Maven project: ```bash mkdir my-payabli-app cd my-payabli-app ``` Create a basic `pom.xml` file with the Payabli SDK dependency: ```xml 4.0.0 com.example my-payabli-app 1.0.0 11 11 io.github.payabli sdk-java [0.0.293,) ``` Create the Maven directory structure: ```bash mkdir -p src/main/java/com/example ``` Create a new file called `PayabliExample.java` in `src/main/java/com/example/`: ```bash touch src/main/java/com/example/PayabliExample.java ``` Open the `PayabliExample.java` file in your code editor. The interactive walkthrough displays code examples alongside step-by-step explanations. Follow the walkthrough to use the SDK in your Java code. {/* Hidden markdown content for server rendering and AI ingestion */}
/// Import the SDK classes Import the Payabli SDK to make it available in your code. ```java // PayabliExample.java package main.java.com.example; import io.github.payabli.api.PayabliApiClient; import io.github.payabli.api.PayabliApiClientBuilder; import io.github.payabli.api.resources.moneyin.requests.RequestPayment; import io.github.payabli.api.resources.moneyin.types.PayabliApiResponseGetPaid; import io.github.payabli.api.resources.moneyin.types.TransRequestBody; import io.github.payabli.api.types.PaymentDetail; import io.github.payabli.api.types.PaymentMethod; import io.github.payabli.api.types.PayMethodCredit; import io.github.payabli.api.types.PayorDataRequest; ``` /// Initialize the client Create an authenticated client instance with your API key. This client has methods that call Payabli's API endpoints. ```java focus=16-18 // PayabliExample.java package main.java.com.example; import io.github.payabli.api.PayabliApiClient; import io.github.payabli.api.PayabliApiClientBuilder; import io.github.payabli.api.resources.moneyin.requests.RequestPayment; import io.github.payabli.api.resources.moneyin.types.PayabliApiResponseGetPaid; import io.github.payabli.api.resources.moneyin.types.TransRequestBody; import io.github.payabli.api.types.PaymentDetail; import io.github.payabli.api.types.PaymentMethod; import io.github.payabli.api.types.PayMethodCredit; import io.github.payabli.api.types.PayorDataRequest; public class PayabliExample { public static void main(String[] args) { PayabliApiClient client = new PayabliApiClientBuilder() .apiKey("REPLACE_WITH_YOUR_API_KEY") .build(); } } ``` /// Build the payment request Construct a request object that contains all the necessary fields to process a transaction. Include payment details, a payment method, and customer data. ```java focus=20-44 // PayabliExample.java package main.java.com.example; import io.github.payabli.api.PayabliApiClient; import io.github.payabli.api.PayabliApiClientBuilder; import io.github.payabli.api.resources.moneyin.requests.RequestPayment; import io.github.payabli.api.resources.moneyin.types.PayabliApiResponseGetPaid; import io.github.payabli.api.resources.moneyin.types.TransRequestBody; import io.github.payabli.api.types.PaymentDetail; import io.github.payabli.api.types.PaymentMethod; import io.github.payabli.api.types.PayMethodCredit; import io.github.payabli.api.types.PayorDataRequest; public class PayabliExample { public static void main(String[] args) { PayabliApiClient client = new PayabliApiClientBuilder() .apiKey("REPLACE_WITH_YOUR_API_KEY") .build(); PaymentDetail paymentDetails = PaymentDetail.builder() .totalAmount(100.0) .serviceFee(0.0) .build(); PayorDataRequest customerData = PayorDataRequest.builder() .customerId(4440L) .build(); PayMethodCredit paymentMethod = PayMethodCredit.builder() .cardexp("02/27") .cardnumber("4111111111111111") .cardcvv("999") .cardHolder("Kassiane Cassian") .cardzip("12345") .initiator("payor") .build(); TransRequestBody requestBody = TransRequestBody.builder() .paymentDetails(paymentDetails) .paymentMethod(PaymentMethod.of(paymentMethod)) .customerData(customerData) .entryPoint("REPLACE_WITH_YOUR_ENTRYPOINT") .ipaddress("255.255.255.255") .build(); } } ``` /// Execute the transaction Call `moneyIn().getpaid()` to process the transaction. The client calls Payabli's `POST /MoneyIn/getpaid` endpoint. ```java focus=50 // PayabliExample.java package main.java.com.example; import io.github.payabli.api.PayabliApiClient; import io.github.payabli.api.PayabliApiClientBuilder; import io.github.payabli.api.resources.moneyin.requests.RequestPayment; import io.github.payabli.api.resources.moneyin.types.PayabliApiResponseGetPaid; import io.github.payabli.api.resources.moneyin.types.TransRequestBody; import io.github.payabli.api.types.PaymentDetail; import io.github.payabli.api.types.PaymentMethod; import io.github.payabli.api.types.PayMethodCredit; import io.github.payabli.api.types.PayorDataRequest; public class PayabliExample { public static void main(String[] args) { PayabliApiClient client = new PayabliApiClientBuilder() .apiKey("REPLACE_WITH_YOUR_API_KEY") .build(); PaymentDetail paymentDetails = PaymentDetail.builder() .totalAmount(100.0) .serviceFee(0.0) .build(); PayorDataRequest customerData = PayorDataRequest.builder() .customerId(4440L) .build(); PayMethodCredit paymentMethod = PayMethodCredit.builder() .cardexp("02/27") .cardnumber("4111111111111111") .cardcvv("999") .cardHolder("Kassiane Cassian") .cardzip("12345") .initiator("payor") .build(); TransRequestBody requestBody = TransRequestBody.builder() .paymentDetails(paymentDetails) .paymentMethod(PaymentMethod.of(paymentMethod)) .customerData(customerData) .entryPoint("REPLACE_WITH_YOUR_ENTRYPOINT") .ipaddress("255.255.255.255") .build(); RequestPayment request = RequestPayment.builder() .body(requestBody) .build(); PayabliApiResponseGetPaid result = client.moneyIn().getpaid(request); } } ``` /// Show the result Log the transaction response. Check the output to see if the transaction was successful. ```java focus=52 // PayabliExample.java package main.java.com.example; import io.github.payabli.api.PayabliApiClient; import io.github.payabli.api.PayabliApiClientBuilder; import io.github.payabli.api.resources.moneyin.requests.RequestPayment; import io.github.payabli.api.resources.moneyin.types.PayabliApiResponseGetPaid; import io.github.payabli.api.resources.moneyin.types.TransRequestBody; import io.github.payabli.api.types.PaymentDetail; import io.github.payabli.api.types.PaymentMethod; import io.github.payabli.api.types.PayMethodCredit; import io.github.payabli.api.types.PayorDataRequest; public class PayabliExample { public static void main(String[] args) { PayabliApiClient client = new PayabliApiClientBuilder() .apiKey("REPLACE_WITH_YOUR_API_KEY") .build(); PaymentDetail paymentDetails = PaymentDetail.builder() .totalAmount(100.0) .serviceFee(0.0) .build(); PayorDataRequest customerData = PayorDataRequest.builder() .customerId(4440L) .build(); PayMethodCredit paymentMethod = PayMethodCredit.builder() .cardexp("02/27") .cardnumber("4111111111111111") .cardcvv("999") .cardHolder("Kassiane Cassian") .cardzip("12345") .initiator("payor") .build(); TransRequestBody requestBody = TransRequestBody.builder() .paymentDetails(paymentDetails) .paymentMethod(PaymentMethod.of(paymentMethod)) .customerData(customerData) .entryPoint("REPLACE_WITH_YOUR_ENTRYPOINT") .ipaddress("255.255.255.255") .build(); RequestPayment request = RequestPayment.builder() .body(requestBody) .build(); PayabliApiResponseGetPaid result = client.moneyIn().getpaid(request); System.out.println(result); } } ```
Compile and run the app with Maven: ```bash mvn clean compile exec:java -Dexec.mainClass="com.example.PayabliExample" ``` Check the console output for the result of the transaction. A successful transaction returns output like this: ```txt PayabliApiResponseGetPaid( responseText=Success, isSuccess=true, pageIdentifier=null, responseData=ResponseData( authCode=TAS003, referenceId=255-67bc92c141e24f474f60c1968fcba0cd, resultCode=1, resultText=Approved, avsResponseText=No Match, No address or ZIP match, cvvResponseText=CVV2/CVC2 match, customerId=4440, methodReferenceId=null ) ) ```
In production, we recommend that you pass a stored method ID to the `paymentMethod` object instead of card details. See more information in [Tokenization Overview](/guides/platform-tokenization-overview). ## SDK example app The SDK example app is a basic web app built with the Payabli Java SDK. It demonstrates how to manage customers and use the temporary token flow with the SDK. The code is publicly available in the [example repository](https://github.com/payabli/examples/tree/main/sdk/java-sdk). customer creation page of SDK example app ### Set up the app Follow these steps to set up the SDK example app on your local machine: Open your terminal and run the following command to clone the SDK example app repository: ```bash git clone https://github.com/payabli/examples ``` In your terminal, navigate to the directory containing the SDK example app: ```bash cd examples/sdk/java-sdk ``` Install the SDK and dependencies: ```bash mvn clean install ``` Copy the`.env.template` file to a new file called `.env`: ```bash cp .env.template .env ``` Open the `.env` file in your code editor. Set `PAYABLI_KEY` to a private API token, `PAYABLI_ENTRY` to your Payabli entrypoint, and `PAYABLI_PUBLIC_TOKEN` to a public API token: ```bash # your Payabli Private API token PAYABLI_KEY="o.Oim...Mekgjw=" # your Payabli entrypoint PAYABLI_ENTRY="41xxxxxa7e" # your Payabli Public API token PAYABLI_PUBLIC_TOKEN="o.Oim...Mekgjw=" ``` Run this command to start the development server, and open the app in your browser: ```bash mvn exec:java ``` ### Use the app The SDK example app has three pages: 1. **Create Customer** - Create a new customer in the Payabli entrypoint. 2. **List Customers** - View a list of all customers in the Payabli entrypoint. 3. **Make Transaction** - Make a transaction using the temporary token flow. #### Create customer The **Create Customer** page has a form that allows you to create a new customer. Fill in the form with the customer's information and click the "Create" button. If the customer is created successfully, a green success message appears below the button. #### List customers The **List Customers** page has a table of all customers in the entrypoint. You can view the customer's information, including their name, email address, and ZIP Code. Click the "X" button on the right side of a customer's row to delete the customer. If the customer is deleted successfully, the row is removed from the table. #### Make transaction The **Make Transaction** page contains an EmbeddedMethod UI component using the temporary token flow. Fill in the form with payment information and click the "Process" button when the payment information is valid. The app performs these steps: 1. The embedded component saves the payment method as a temporary token and sends it to the server. 2. The server converts the temporary token to a permanent token with the **POST TokenStorage/add** endpoint. 3. The server uses the permanent token to make a transaction with the **POST MoneyIn/getpaid** endpoint. If everything is successful, a green success message appears below the embedded component. See [Extend embedded components with the temporary token flow](/guides/platform-developer-tokenization-temp-flow) for more information.