URBAN BASE Code

Gumroad License Keys mit PHP und cURL überprüfen

PHP Tutorial - Gumroad License Keys mit PHP und cURL überprüfenPHP Tutorial - Gumroad License Keys mit PHP und cURL überprüfen

Gumroad ist eine Plattform über die du deine Produkte verkaufen kannst.

Mittlerweile bietet Gumroad auch an Lizenzschlüssel zu generieren, so kannst du Software auf deiner Webseite zum Download anbieten und den Lizenzschlüssel über Gumroad verkaufen.

Wenn der Kunde dann den Lizenzschlüssel eingibt kann deine Software eine Verbindung zu einem Gumroad-Server aufnehmen und den Schlüssel überprüfen.

In meinem Fall zeige ich dir wie das mit PHP funktioniert, wenn du zum Beispiel ein WordPress Plugin machst mit Premium-Funktionen.

Auf Gumroad findest du nur diese Information zu dem Thema: https://help.gumroad.com/11165-digging-deeper/license-keys

Ich habe nur sehr wenig im Internet speziell zu diesem Thema gefunden, deshalb musste ich mir dieses Wissen selbst zusammensuchen.

Mehr Informationen zu cURL auf Wikipedia und cURL auf php.net

Die Funktion in PHP

function gumroad_licence($licence_key)
{
    $curl = curl_init();

    $post_data = array(
        'product_permalink' => 'QMGY',
        'license_key' => $licence_key,
        'increment_uses_count' => 'false'
    );

    $url = "https://api.gumroad.com/v2/licenses/verify";

    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($curl, CURLOPT_POST, 1);
    curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);

    $result = curl_exec($curl);

    $array = json_decode($result, true);

    if ($array['success'] === true) {
        return $array;
    } else {
        return false;
    }

    curl_close($curl);
}




Aufbau der Funktion

Die Funktion bekommt als Input den Lizenzschlüssel: $licence_key

curl_init(); startet die cURL-Abfrage.

Es handelt sich um eine Abfrage mit POST, deshalb werden hier folgende Werte in einem Array mitgegeben:

$post_data = array(
    'product_permalink' => 'QMGY',
    'license_key' => $licence_key,
    'increment_uses_count' => 'false'
);

Bei product_permalink steht in meinem Beispiel „QMGY“, das ist die ID deines Produktes auf Gumroad, als URL würde das so aussehen: https://gumroad.com/l/QMGY dabei handelt es sich um ein Lizenz-Demo-Produkt von Gumroad.

Als zweite wird license_key mitgegeben und increment_uses_count habe ich hier auf false gesetzt, wenn du es auf true setzt, dann wird bei jeder Abfrage ein Zähler um eins erhöht, mit false nicht, damit kannst du überprüfen wie oft dieser Lizenzschlüssel schon eingegeben wurde.

$url = "https://api.gumroad.com/v2/licenses/verify"; ist die API-URL von Gumroad.

Mit curl_setopt() werden die Parameter der cURL-Abfrage gesetzt, diese kannst du so übernehmen.

curl_exec() führt die cURL anweisung aus, da von Gumroad aber ein JSON-Format zurück kommt und ich aber ein assoziatives Array haben will verwende ich json_decode().

Die IF-Abfrage zum Schluss prüft ob der Lizenzschlüssel korrekt war , denn dann kommt ein „success“ von Gumroad zurück und ich gebe das Array als Rückgabe-Wert der Funktion zurück. Ansonsten wird false zurückgegeben.

Die Anwendung

Zur Überprüfung was von Gumroad alles als Antwort kommt kannst du das gesamten Rückgabe-Array mit var_dump() einmal ausgeben:

$licence_key = "1234ABCD-1234ABCD-1234ABCD-1234ABCD";
$gumroad_array = gumroad_licence($licence_key);
var_dump($gumroad_array);

Als Rückgabe bekommst du dann ein Array auf das du wie gewohnt zugreifen kannst mit Daten wie:

Es gibt noch mehr Daten die du abrufen kannst, diese siehst du aber bei der Ausgabe des Arrays mit var_dump($gumroad_array).

Die mobile Version verlassen