Heim >Datenbank >MySQL-Tutorial >Wie generiert man vertrauliche, sortierbare und kompakte eindeutige ganzzahlige Primärschlüssel in Django?

Wie generiert man vertrauliche, sortierbare und kompakte eindeutige ganzzahlige Primärschlüssel in Django?

Susan Sarandon
Susan SarandonOriginal
2024-12-08 20:52:16704Durchsuche

How to Generate Confidential, Sortable, and Compact Unique Integer Primary Keys in Django?

Eindeutige ganzzahlige Primärschlüssel in Django: Vertraulichkeit ohne Geschwindigkeitseinbußen erreichen

Offengelegte Primärschlüssel können Sicherheitsbedenken aufwerfen. Um dieses Problem zu beheben, versuchen Entwickler häufig, den automatisch inkrementierten Standard-Primärschlüssel durch eine eindeutige Ganzzahl zu ersetzen, die nicht leicht zu erraten oder aufzuzählen ist. Während das Hashing des Originalschlüssels eine gängige Lösung ist, führt es zu einem Leistungsaufwand und der Notwendigkeit einer Konvertierung bei jedem Zugriff auf den Schlüssel.

In diesem Artikel stellen wir einen alternativen Ansatz vor, der vom Ansatz von Instagram inspiriert ist. Unsere Lösung generiert einen eindeutigen Ganzzahlschlüssel, der die folgenden Kriterien erfüllt:

  • Ganzzahltyp: Behält den Primärschlüsselfeldtyp als Ganzzahl bei.
  • Zeitbasierte Komponente: Enthält eine zeitbasierte Komponente, um die Sortierbarkeit durch Einfügen sicherzustellen Zeit.
  • Einzigartig pro Tabelle: Garantiert Eindeutigkeit nur innerhalb der spezifischen Tabelle, nicht global.
  • Minimale Länge: Strebt eine kompakte Schlüssellänge an um übermäßige URLs zu vermeiden Länge.

Implementierung

IDs generieren:

START_TIME = <unix timestamp constant>

def make_id():
    t = int(time.time()*1000) - START_TIME
    u = random.SystemRandom().getrandbits(23)
    id = (t << 23 ) | u
    return id

Die Modell:

class MyClass(models.Model):
   id = models.BigIntegerField(default = fields.make_id, primary_key=True)  

Vorteile

  • Vertraulichkeit: Versteckt die Anzahl der Zeilen in einer Tabelle vor der öffentlichen Ansicht.
  • Leistung: Vermeidet unnötiges Hashing Operationen.
  • Kompaktheit: Erzeugt Schlüsselwerte, die im Allgemeinen kürzer als Hashes sind.

Dieser Ansatz geht effektiv auf die aufgeworfenen Bedenken ein und erfüllt gleichzeitig die spezifischen Anforderungen eines Unikats Ganzzahliger Primärschlüssel ohne Beeinträchtigung der Leistung oder Speichereffizienz.

Das obige ist der detaillierte Inhalt vonWie generiert man vertrauliche, sortierbare und kompakte eindeutige ganzzahlige Primärschlüssel in Django?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn