Diese Seite funktioniert am besten mit aktiviertem JavaScript!

Beschreibung: Zufallsgenerator - JA / NEIN

Zufallsgenerator Ja Nein

In diesem Artikel wird die Funktionsweise des Zufallsgenerators "Ja / Nein" beschrieben. Dieser Generator erzeugt zufällig die Antwort Ja oder Nein. Wenn du dir unsicher bist und ein Orakel benötigst, dann bist du hier genau richtig. Dank dem kryptografisch sicheren Zufallsgenerator musst du selbst keine Entscheidung mehr treffen.


Anzeige
Andreas Goldemann: Zurück zum Ursprung

Was ist Zufall?

Als Zufall bezeichnet man ein Ereignis, dessen Zustand kausal nicht eindeutig vorherbestimmbar ist. Das bedeutet, dass das Ergebnis eines Zufallsgenerators nicht vorhersehbar bzw. berechenbar sein darf. Dies widerspricht jedoch den Gesetzmäßigkeiten eines jeden Computers, was im Umkehrschluss bedeutet, dass ein Computer ohne weitere Peripherie keine absolut zufälligen Zahlen erzeugen kann. Man spricht in diesem Fall von Pseudo-Zufallszahlen. Generell lässt sich darüber philosophieren, ab wann man in der Praxis tatsächlich von echtem Zufall sprechen kann.

Wie werden die Zufallswerte generiert?

Theoretisch werden in diesem Generator mehrere unterschiedliche Methoden zur Erzeugung von Pseudo-Zufallswerten eingesetzt. Für die eigentliche "Ja/Nein"-Antwort wird dabei eine PHP-Funktion für kryptographisch sichere Pseudo-Zufallszahlen verwendet.

Zufallsgeneratoren für Binärstring

Sinn und Zweck des Binärstrings ist einerseits die bessere Optik und andererseits die Tatsache, dass dadurch vom Nutzer sichergestellt werden kann, dass auch tatsächlich ein neuer Zufallswert erzeugt worden ist.

Der serverseitig generierte Binärstring ist nur dann sichtbar, wenn JavaScript deaktiviert ist. Dazu werden die PHP-Funktionen mt_rand() und decbin() eingesetzt. Die erste Funktion erzeugt die eigentlich Zufallszahl und die zweite dient zur Konvertierung der Dezimalzahl in eine Binärzahl. Prinzipiell wird folgender Algorithmus angewendet:

1
2
3
4
5
$random_string = "";
while (strlen($random_string) < GEWÜNSCHTE_LÄNGE)
{
   $random_string .= decbin(mt_rand(ZAHL1, ZAHL2));
}

In einer früheren Version dieses Zufallsgenerators wurde der Binärstring auch bei aktiviertem JavaScript clientseitig mit Hilfe eines modifizierten Fisher-Yates-Verfahrens erzeugt:

1
2
3
4
5
6
7
8
9
10
var string = "010010101010010101010101010110101010101001011010";
var n = string.length;

for (var i = n - 1; i > 0; i--)
{
   var j = Math.floor(Math.random() * (i + 1));
   var tmp = string[i];
   string[i] = string[j];
   string[j] = tmp;
}

Zufallsgenerator für Zufallsantwort

Die zuvor genannten Methoden erzeugen einigermaßen gute Zufallszahlen, welche jedoch noch verbesserungsfähig sind. Die Erzeugung der Zufallsantwort erfolgt daher stets serverseitig durch die PHP-Funktion random_int(), welche kryptographisch sichere Pseudo-Zufallszahlen generiert:

1
2
3
4
5
6
7
8
if ((bool)random_int(0, 1))
{
   $zufallsantwort = "JA";
}
else
{
   $zufallsantwort = "NEIN";
}
ZUM ZUFALLSGENERATOR
Teile diese Seite
Erstellt am 20.11.2016 | Zuletzt geändert am 07.04.2021