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:

select sqids.encode(array[1, 2, 3], 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789', 0); -- 86Rf07
select sqids.decode('86Rf07', 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'); -- {1,2,3}

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

select sqids.encode(array[1, 2, 3], 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789', 10); -- 86Rf07xd4z
select sqids.decode('86Rf07xd4z', 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'); -- {1,2,3}

Maak unieke ID's door het alfabet te schudden:

select sqids.encode(array[1, 2, 3], 'k3G7QAe51FCsPW92uEOyq4Bg6Sp8YzVTmnU0liwDdHXLajZrfxNhobJIRcMvKt', 0); -- XRKUdQ
select sqids.decode('XRKUdQ', 'k3G7QAe51FCsPW92uEOyq4Bg6Sp8YzVTmnU0liwDdHXLajZrfxNhobJIRcMvKt'); -- {1,2,3}

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

Als je op zoek bent naar het originele Hashids PLpgSQL, je kunt het hier vinden: https://github.com/array-analytics/plpg_hashids

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
  • ๐Ÿฅณ 44 integraties (75% gebruikt een nieuw ontwerp)
  • ๐Ÿ“Œ Elke versie produceert dezelfde ID's
  • ๐Ÿป Kleine bibliotheek met een toegeeflijke licentie

Voorbeeld / Speeltuin