Was ist Sqids?

Sqids ist eine Open-Source-Bibliothek, die es Ihnen ermöglicht, kurze eindeutige Bezeichner aus Zahlen zu generieren. Diese IDs sind URL-sicher, können mehrere Zahlen codieren und enthalten keine gängigen unangemessenen Wörter. Mehr lesen .

So sehen sie aus:

https://example.com/Lqj8a0

Schnelles Kodierungs- & Dekodierungsbeispiel:

Sqids *sqids = [[Sqids alloc] init];
NSString *id_ = [sqids encode:@[@1, @2, @3] error:nil]; // @"86Rf07"
NSArray<NSNumber *> *numbers = [sqids decode:id_]; // @[@1, @2, @3]

Wenn IDs zu kurz sind, können Sie sie auf eine bestimmte Länge auffüllen:

SqidsOptions *options = [[SqidsOptions alloc] init];
options.minLength = @10;
Sqids *sqids = [[Sqids alloc] initWithOptions:options];
NSString *id_ = [sqids encode:@[@1, @2, @3] error:nil]; // @"86Rf07xd4z"
NSArray<NSNumber *> *numbers = [sqids decode:id_]; // @[@1, @2, @3]

Erstellen Sie eindeutige IDs durch Mischen des Alphabets:

SqidsOptions *options = [[SqidsOptions alloc] init];
options.alphabet = @"k3G7QAe51FCsPW92uEOyq4Bg6Sp8YzVTmnU0liwDdHXLajZrfxNhobJIRcMvKt";
Sqids *sqids = [[Sqids alloc] initWithOptions:options];
NSString *id_ = [sqids encode:@[@1, @2, @3] error:nil]; // @"XRKUdQ"
NSArray<NSNumber *> *numbers = [sqids decode:id_]; // @[@1, @2, @3]

Die vollständige Dokumentation befindet sich unter https://github.com/sqids/sqids-objective-c

Wenn Sie nach dem originalen Hashids Objective-C suchen, finden Sie es hier: https://github.com/DrGodCarl/hashids-objc

Anwendungsfälle

Der Hauptzweck von Sqids ist rein visuell. Wenn Sie in Ihrem Projekt IDs anstelle von Zahlen verwenden möchten, könnte Sqids eine gute Wahl sein.

Gut für

  • Primärschlüssel codieren Wenn Sie eine relationale Datenbank verwenden
  • Datenbankabfragen sparen Durch Codieren mehrerer Objekte
  • Temporäre Anmelde-Token Schimpfwortfrei und URL-sicher

Nicht gut für

  • Sensible Daten Dies ist keine Verschlüsselungsbibliothek
  • Benutzer-IDs Kann die Benutzeranzahl preisgeben, wenn jemand das Codierungsalphabet herausfindet

Funktionen

  • 🆔 Kurze IDs aus nicht-negativen Zahlen generieren
  • Einfache Codierung und Dekodierung
  • 🫣 Automatisch generierte IDs enthalten keine üblichen Schimpfwörter
  • 🎲 Unterstützung für benutzerdefinierte IDs durch gemischtes Alphabet
  • 🥳 44 Integrationen (75% verwenden ein neues Design)
  • 📌 Jede Version erzeugt dieselben IDs
  • 🍻 Kleine Bibliothek mit einer großzügigen Lizenz

Beispiel / Spielplatz