This is the official Mixpanel tracking library for Java.
May 08, 2024 - v1.5.3
<dependency>
<groupId>com.mixpanel</groupId>
<artifactId>mixpanel-java</artifactId>
<version>1.5.3</version>
</dependency>
You can alternatively download the library jar directly from Maven Central here.
The library is designed to produce events and people updates in one process or thread, and
consume the events and people updates in another thread or process. Specially formatted JSON objects
are built by MessageBuilder
objects, and those messages can be consumed by the
MixpanelAPI
via ClientDelivery
objects, possibly after serialization or IPC.
MessageBuilder messages = new MessageBuilder("my token");
JSONObject event = messages.event("joe@gribbl.com", "Logged In", null);
// Later, or elsewhere...
ClientDelivery delivery = new ClientDelivery();
delivery.addMessage(event);
MixpanelAPI mixpanel = new MixpanelAPI();
mixpanel.deliver(delivery);
The library supports gzip compression for both tracking events (/track
) and importing historical events (/import
). To enable gzip compression, pass true
to the MixpanelAPI
constructor:
MixpanelAPI mixpanel = new MixpanelAPI(true); // Enable gzip compression
Gzip compression can reduce bandwidth usage and improve performance, especially when sending large batches of events.
The library supports importing historical events (events older than 5 days that are not accepted using /track) via the /import
endpoint. Project token will be used for basic auth.
This library in particular has more in-depth documentation at
https://mixpanel.com/docs/integration-libraries/java
Mixpanel maintains documentation at
http://www.mixpanel.com/docs
The library also contains a simple demo application, that demonstrates using this library in an asynchronous environment.
There are also community supported libraries in addition to this library, that provide a threading model, support for dealing directly with Java Servlet requests, support for persistent properties, etc. Two interesting ones are at:
https://github.com/eranation/mixpanel-java
https://github.com/scalascope/mixpanel-java
Mixpanel also maintains a full-featured library for tracking events from Android apps at https://github.com/mixpanel/mixpanel-android
And a full-featured client side library for web applications, in Javascript, that can be loaded directly from Mixpanel servers. To learn more about our Javascript library, see: https://mixpanel.com/docs/integration-libraries/javascript
This library is intended for use in back end applications or API services that can't take advantage of the Android libraries or the Javascript library.
See LICENSE File for details. The Base64Coder class used by this software
has been licensed from non-Mixpanel sources and modified for use in the library.
Please see Base64Coder.java for details.