Wat is Sqids?

Sqids is een open-source bibliotheek waarmee je korte unieke identifiers kunt genereren vanuit nummers. Deze ID's zijn URL-veilig, kunnen verschillende nummers encoderen en bevatten geen gangbare grove woorden. Lees meer .

Dit is hoe ze eruit zien:

https://example.com/Lqj8a0

Snel encode & decode voorbeeld:

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

Als ID's te kort zijn, kun je ze opvullen tot een bepaalde lengte:

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]

Maak unieke ID's door het alfabet te schudden:

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]

De volledige documentatie is te vinden op https://github.com/sqids/sqids-objective-c

Als je op zoek bent naar het originele Hashids Objective-C, je kunt het hier vinden: https://github.com/DrGodCarl/hashids-objc

Gebruiksscenario's

Het hoofdgebruik van Sqids is puur visueel. Als je IDs in plaats van nummers wilt gebruiken in je project, kan Sqids een goede keuze zijn.

Goed voor

  • Coderen van primaire sleutels Als je een relationele database gebruikt
  • Besparen van databasezoekopdrachten Door meerdere objecten te coderen
  • Tijdelijke inlogtokens Vrij van grof taalgebruik en URL-veilig

Niet geschikt voor

  • Gevoelige data Dit is geen encryptiebibliotheek
  • Gebruikers-IDs Kan het aantal gebruikers onthullen als iemand het coderingsalfabet ontdekt

Functies

  • ๐Ÿ†” Genereer korte ID's van niet-negatieve getallen
  • โœ… Eenvoudig coderen en decoderen
  • ๐Ÿซฃ Automatisch gegenereerde ID's bevatten geen veelvoorkomend grof taalgebruik
  • ๐ŸŽฒ Ondersteuning voor aangepaste ID's via een geschud alfabet
  • ๐Ÿฅณ 45 integraties (84% gebruikt een nieuw ontwerp)
  • ๐Ÿ“Œ Elke versie produceert dezelfde ID's
  • ๐Ÿป Kleine bibliotheek met een toegeeflijke licentie

Voorbeeld / Speeltuin