This SDK contains methods for interacting easily with ZeroBounce API.
More information about ZeroBounce you can find in the official documentation.
This SDK is built using the Java 21 version.
You can install ZeroBounceSDK by adding the dependency to your pom.xml file:
<dependency>
<groupId>com.zerobounce.java</groupId>
<artifactId>zerobouncesdk</artifactId>
<version><latest_version></version>
</dependency>- Build the JAR file for the SDK project.
- Make sure there's no other JAR located in the maven cache file. On my machine, it is located here:
~/.m2/repository/com/zerobounce/java/zerobouncesdk/ - Run the following command from the root of the project:
mvn org.apache.maven.plugins:maven-install-plugin:2.3.1:install-file \ -Dfile=zero-bounce-sdk/out/artifacts/zerobouncesdk_jar/zerobouncesdk.jar \ -DgroupId=com.zerobounce.java \ -DartifactId=zerobouncesdk \ -Dversion=<latest_version> \ -Dpackaging=jar \ -DlocalRepositoryPath=local-libs - Run
mvn clean dependency:purge-local-repositoryin the Sample project. - Run
mvn compilein the Sample project. - Rebuild the Sample project.
- Run & enjoy!
We highly recommend you use the latest version available on Maven. However, if you plan on bundling the repository version of the SDK in your project, then here's what you need to do:
- Create a folder named local-libs in the root of your project, that will act as a "local" repository.
- In your
pom.xmlfile paste the following code that will use a "local" repository:<repositories> <repository> <id>local-repo</id> <name>Local Repo</name> <url>file://${project.basedir}/local-libs</url> </repository> </repositories>
- Inside the
<dependencies></dependencies>block, paste the following code:<dependency> <groupId>com.zerobounce.java</groupId> <artifactId>zerobouncesdk</artifactId> <version><latest_version></version> </dependency>
- Follow steps 1-5 from the How to use the sample project above.
- Rebuild the project.
- Enjoy!
- Be sure to set the autoReleaseAfterClose field to false in the
pom.xmlfile of the zero-bounce-sdk if you don't want the artifact to be automatically deployed on Maven Central. - Use the command:
mvn --no-transfer-progress --batch-mode -Dgpg.passphrase=<YOUR_PASSPHRASE> clean deploy -Preleasefrom the zero-bounce-sdk folder.
Initialize the sdk with your api key:
ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>");ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>", timeoutInMillis);ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>", "<YOUR_API_BASE_URL>");The SDK is silent by default so it never emits Personally Identifiable Information (PII) unless you
explicitly opt in. To integrate the SDK with your application's logging framework, register a
ZBLogger implementation before issuing any API calls. The helper class ZBLoggers adapts
java.util.logging (JUL) out of the box:
import com.zerobounce.ZBLoggers;
ZeroBounceSDK.setLogger(
ZBLoggers.jul(java.util.logging.Logger.getLogger("ZeroBounceSDK"))
);
// Optional: enable verbose payload logging for troubleshooting only.
ZeroBounceSDK.setLogPayloads(true);Passing null to ZeroBounceSDK.setLogger(...) resets the logger to a no-op implementation, which
disables SDK logging again.
Note: The snippets below print responses for demonstration purposes. Avoid logging raw API data that may contain PII in production systems.
Then you can use any of the SDK methods, for example:
-
ZeroBounceSDK.getInstance().validate( "<ANY_EMAIL_ADDRESS>", "<OPTIONAL_IP_ADDRESS>", new ZeroBounceSDK.OnSuccessCallback<ZBValidateResponse>() { @Override public void onSuccess(ZBValidateResponse response) { System.out.println("validate response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("validate error=" + errorMessage); } }); );
-
List<ZBValidateBatchData> emailsData = new ArrayList<ZBValidateBatchData>(); emailsData.add(new ZBValidateBatchData("[email protected]", "1.1.1.1")); emailsData.add(new ZBValidateBatchData("[email protected]", "1.1.1.1")); emailsData.add(new ZBValidateBatchData("[email protected]", null)); ZeroBounceSDK.getInstance().validateBatch( emailsData, new ZeroBounceSDK.OnSuccessCallback<ZBValidateBatchResponse>() { @Override public void onSuccess(ZBValidateBatchResponse response) { System.out.println("validateBatch response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("validateBatch error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().guessFormat( "<DOMAIN_TO_TEST>", null, null, null, new ZeroBounceSDK.OnSuccessCallback<ZBEmailFinderResponse>() { @Override public void onSuccess(ZBEmailFinderResponse response) { System.out.println("guessFormat response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("guessFormat error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findEmail( "<FIRST_NAME_TO_TEST>" "<DOMAIN_TO_TEST>", null, null, null, new ZeroBounceSDK.OnSuccessCallback<ZBFindEmailResponse>() { @Override public void onSuccess(ZBFindEmailResponse response) { System.out.println("findEmail response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findEmail error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findEmail( "<FIRST_NAME_TO_TEST>" null, "<COMPANY_NAME_TO_TEST>", null, null, new ZeroBounceSDK.OnSuccessCallback<ZBFindEmailResponse>() { @Override public void onSuccess(ZBFindEmailResponse response) { System.out.println("findEmail response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findEmail error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findDomain( "<DOMAIN_TO_TEST>", null, new ZeroBounceSDK.OnSuccessCallback<ZBFindDomainResponse>() { @Override public void onSuccess(ZBFindDomainResponse response) { System.out.println("findDomain response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findDomain error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findDomain( null, "COMPANY_NAME_TO_TEST", new ZeroBounceSDK.OnSuccessCallback<ZBFindDomainResponse>() { @Override public void onSuccess(ZBFindDomainResponse response) { System.out.println("findDomain response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findDomain error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().getCredits( new ZeroBounceSDK.OnSuccessCallback<ZBCreditsResponse>() { @Override public void onSuccess(ZBCreditsResponse response) { System.out.println("getCredits response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("getCredits error=" + errorMessage); } });
-
Date startDate = new Date(); // The start date of when you want to view API usage Date endDate = new Date(); // The end date of when you want to view API usage ZeroBounceSDK.getInstance().getApiUsage( startDate, endDate, new ZeroBounceSDK.OnSuccessCallback<ZBGetApiUsageResponse>() { @Override public void onSuccess(ZBGetApiUsageResponse response) { System.out.println("getApiUsage response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("getApiUsage error=" + errorMessage); } });
-
File myFile = new File("<FILE_PATH>"); // The csv or txt file int emailAddressColumn = 3; // The column index of the email address in the file. Index starts at 1 ZeroBounceSDK.getInstance().sendFile( myFile, emailAddressColumn, null, new ZeroBounceSDK.OnSuccessCallback<ZBSendFileResponse>() { @Override public void onSuccess(ZBSendFileResponse response) { System.out.println("sendFile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("sendFile error=" + errorMessage); } });
-
The getFile API allows users to get the validation results file for the file been submitted using sendFile API
String fileId = "<FILE_ID>"; // The returned file ID when calling sendfile API String downloadPath = "<FILE_DOWNLOAD_PATH>"; // The path where the file will be downloaded ZeroBounceSDK.getInstance().getFile( fileId, downloadPath, new ZeroBounceSDK.OnSuccessCallback<ZBGetFileResponse>() { @Override public void onSuccess(ZBGetFileResponse response) { System.out.println("getfile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("getfile error=" + errorMessage); } });
-
String fileId = "<FILE_ID>"; // The returned file ID when calling sendfile API ZeroBounceSDK.getInstance().fileStatus( fileId, new ZeroBounceSDK.OnSuccessCallback<ZBFileStatusResponse>() { @Override public void onSuccess(ZBFileStatusResponse response) { System.out.println("fileStatus response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("fileStatus error=" + errorMessage); } });
-
Delete the file that was submitted using sendFile API. File can be deleted only when its status is
CompleteString fileId = "<FILE_ID>"; // The returned file ID when calling sendfile API ZeroBounceSDK.getInstance().deleteFile( fileId, new ZeroBounceSDK.OnSuccessCallback<ZBDeleteFileResponse>() { @Override public void onSuccess(ZBDeleteFileResponse response) { System.out.println("deleteFile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("deleteFile error=" + errorMessage); } });
-
Gather insights into your subscribers’ overall email engagement. The request returns data regarding opens, clicks, forwards and unsubscribes that have taken place in the past 30, 90, 180 or 365 days.
ZeroBounceSDK.getInstance().getActivityData( "<ANY_EMAIL_ADDRESS>", new ZeroBounceSDK.OnSuccessCallback<ZBActivityDataResponse>() { @Override public void onSuccess(ZBActivityDataResponse response) { System.out.println("getActivityData response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("getActivityData error=" + errorMessage); } });
-
File myFile = new File("<FILE_PATH>"); // The csv or txt file int emailAddressColumn = 3; // The column index of the email address in the file. Index starts at 1 ZeroBounceSDK.getInstance().scoringSendFile( myFile, emailAddressColumn, null, new ZeroBounceSDK.OnSuccessCallback<ZBSendFileResponse>() { @Override public void onSuccess(ZBSendFileResponse response) { System.out.println("scoringSendFile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("scoringSendFile error=" + errorMessage); } });
-
The scoringGetFile API allows users to get the validation results file for the file been submitted using scoringSendFile API
String fileId = "<FILE_ID>"; // The returned file ID when calling scoringSendfile API String downloadPath = "<FILE_DOWNLOAD_PATH>"; // The path where the file will be downloaded ZeroBounceSDK.getInstance().scoringGetFile( fileId, downloadPath, new ZeroBounceSDK.OnSuccessCallback<ZBGetFileResponse>() { @Override public void onSuccess(ZBGetFileResponse response) { System.out.println("scoringGetfile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("scoringGetfile error=" + errorMessage); } });
-
String fileId = "<FILE_ID>"; // The returned file ID when calling scoringSendfile API ZeroBounceSDK.getInstance().scoringFileStatus( fileId, new ZeroBounceSDK.OnSuccessCallback<ZBFileStatusResponse>() { @Override public void onSuccess(ZBFileStatusResponse response) { System.out.println("scoringFileStatus response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("scoringFileStatus error=" + errorMessage); } });
-
Deletes the file that was submitted using scoring scoringSendFile API. File can be deleted only when its status is
CompleteString fileId = "<FILE_ID>"; // The returned file ID when calling scoringSendfile API ZeroBounceSDK.getInstance().scoringDeleteFile( fileId, new ZeroBounceSDK.OnSuccessCallback<ZBDeleteFileResponse>() { @Override public void onSuccess(ZBDeleteFileResponse response) { System.out.println("scoringDeleteFile response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("scoringDeleteFile error=" + errorMessage); } });
guessFormat has been deprecated. To continue using your existing code, you must migrate to findEmail or findDomain .
The change is not a simple one-to-one replacement, as the functionality has been split:
- If you were finding a person's email format, use the new
findEmail()method. - If you were only determining the domain's general email pattern, use the new
findDomain()method.
-
ZeroBounceSDK.getInstance().guessFormat( "<DOMAIN_TO_TEST>", null, null, null, new ZeroBounceSDK.OnSuccessCallback<ZBEmailFinderResponse>() { @Override public void onSuccess(ZBEmailFinderResponse response) { System.out.println("guessFormat response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("guessFormat error=" + errorMessage); } }); );
-
-
ZeroBounceSDK.getInstance().findEmail( "<FIRST_NAME_TO_TEST>" "<DOMAIN_TO_TEST>", null, null, null, new ZeroBounceSDK.OnSuccessCallback<ZBFindEmailResponse>() { @Override public void onSuccess(ZBFindEmailResponse response) { System.out.println("findEmail response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findEmail error=" + errorMessage); } }); );
-
-
ZeroBounceSDK.getInstance().findEmail( "<FIRST_NAME_TO_TEST>" null, "<COMPANY_NAME_TO_TEST>", null, null, new ZeroBounceSDK.OnSuccessCallback<ZBFindEmailResponse>() { @Override public void onSuccess(ZBFindEmailResponse response) { System.out.println("findEmail response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findEmail error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findDomain( "<DOMAIN_TO_TEST>", null, new ZeroBounceSDK.OnSuccessCallback<ZBFindDomainResponse>() { @Override public void onSuccess(ZBFindDomainResponse response) { System.out.println("findDomain response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findDomain error=" + errorMessage); } }); );
-
ZeroBounceSDK.getInstance().findDomain( null, "COMPANY_NAME_TO_TEST", new ZeroBounceSDK.OnSuccessCallback<ZBFindDomainResponse>() { @Override public void onSuccess(ZBFindDomainResponse response) { System.out.println("findDomain response=" + response.toString()); } }, new ZeroBounceSDK.OnErrorCallback() { @Override public void onError(String errorMessage) { System.out.println("findDomain error=" + errorMessage); } }); );
The ZeroBounceSDK.initialize() method can now accepts an apiBaseUrl parameter.
This allows you to specify a custom base URL for the ZeroBounce API.
The existing way of initializing the SDK is still valid.
- Default Usage (No Change Required). If you don't provide a URL, the SDK will continue to use the standard ZeroBounce API endpoint:
ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>");ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>", timeoutInMillis);- Initialize the SDK with your API key and URL:
ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>", "<YOUR_API_BASE_URL>");The SDK now exposes a set of predefined constants for different geographical API endpoints, allowing for more precise network routing.
You can specify a custom API base URL during initialization by using the new optional apiBaseUrl
parameter in initialize(). For convenience, the following constants are available in the
ZBConstants class:
| Constant | URL Value | Description |
|---|---|---|
API_DEFAULT_URL |
https://api.zerobounce.net/v2/ |
The global default endpoint. |
API_USA_URL |
https://api-us.zerobounce.net/v2/ |
The US-specific endpoint for lower latency in the Americas. |
API_EU_URL |
https://api-eu.zerobounce.net/v2/ |
The EU-specific endpoint for compliance and lower latency in Europe. |
To use the EU endpoint for initialization:
ZeroBounceSDK.getInstance().initialize("<YOUR_API_KEY>", ZBConstants.getInstance().API_EU_URL);You can generate the documentation using your desired IDE or using's maven's javadoc command.
Every time a new release is created, the CI/CD pipeline will execute and a new artifact will be released on Maven Central. The pipeline updates the version automatically! If you ever change the OSSRH login credentials, you'll need to also update the repository variables on Github.
In order to be able to publish to the Nexus repository from you local machine, you'll need to do the following step: If you want to manually publish to the Nexus repository (and then release it to Maven Central), you should:
- Import the GPG key to your local machine (see below)
- Set the autoReleaseAfterClose inside the zero-bounce-sdk's
pom.xmlto false. - Run the following command:
# For publishing to the staging repository mvn --no-transfer-progress --batch-mode -Dgpg.passphrase=<YOUR_PASSPHRASE> clean deploy -Prelease
You should then go to the Nexus Sonatype, login and then open Staging Repositories and click on Refresh. Here you'll see the artifact you just uploaded. In order to publish it, you have to close it and then release it. These actions will take a few minutes to complete. After releasing the artifact, it will take:
- a few hours before you can see it on the Maven Repository and on the Sonatype Search
- 1-3 days before you can see it on the MVN Repository
-
Export the keys:
gpg --list-keys # In order to obtain the key hash for the next step gpg --export -a <LAST_8_DIGITS> > public.key gpg --export-secret-key -a <LAST_8_DIGITS> > private key
-
Import the keys:
gpg --import public.key gpg --import private.key
-
Check that the new keys are imported:
gpg --list-keys gpg --list-secret-keys