• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

[gelöst] [PHP] Zufällige Zahlen, Buchstaben & Sonderzeichenkombination macht Probleme

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
Ich habe im Internet ein Script gefunden und das ein wenig für meine Bedürfnisse angepasst.
Grundsätzlich funktioniert es, aber bei der Erstellung des Zufalls-Strings bekomme ich auf der Seite an manchen Stellen ein kryptisches Symbol.

Zuerst dachte ich, dass da wohl einige Zeichen nicht richtig interpretiert werden, weil ich das recht lieblos in eine Test-PHP ohne Doctype und so geschmissen habe, aber als ich mir die einzelnen Strings angeguckt habe um rauszufinden welche Zeichen Probleme machen war alles super.

Hier mal das Script:
PHP:
$for_salt = ("abcdefghijklmnopqrstuvwxyz");
$for_salt .= ("123456789");
$for_salt .= ("äüöß-.,_:;!§$%&/()=?<>");


for ($i=0;$i<100;$i++) {
$tmp = mt_rand(0, strlen($for_salt)-1);
$salt .= $for_salt[$tmp];
}
echo "Salt: ".$salt."<br>";
echo "Test: ".$for_salt;
Ein Ergebis kann dann so aussehen:
Code:
Salt: y�h�6k.!(nc87>�z�8�y)�kr�bgg&sfshb=weü5)djv�22o-,çwi7�g?)�$fk&%%)=�&i�tfgd>yuy,%p;�pt�$%c=2=d)�%�/
Test: abcdefghijklmnopqrstuvwxyz123456789äüöß-.,_:;!§$%&/()=?<>

Was ist nun das Problem und wie behebe ich es?
 
Zuletzt bearbeitet:

Kugelfisch

Nerd

Registriert
12 Juli 2013
Beiträge
2.342
Ort
Im Ozean
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

Das Problem ist, dass du nicht-ASCII-Sonderzeichen (äüöß) in UTF-8-Zeichencodierung nutzt, der Zugriff auf einzelne Zeichen eines Strings jedoch - wie in http://www.php.net/language.types.string.php#language.types.string.substr erwähnt - nicht Multi-Byte-Sicher ist. Dadurch generierst du ungültige UTF-8-Zeichen, welche dann in der Ausgabe als Replacement Character (�) dargestellt werden. Mutmasslich wäre ohnehin sinnvoll, auf nicht-ASCII-Zeichen zu verzichten, möchtest du deinen Algorithmus auf einem UTF-8-String implementieren, müsstest du PHPs Multi-Byte-Stringfunktionen nutzen, z.B.:
PHP:
for ($i=0;$i<100;$i++) {
   $tmp = mt_rand(0, mb_strlen($for_salt,'UTF-8')-1);
   $salt .= mb_substr($for_salt,$tmp,1,'UTF-8');
}


Beachte auch, dass die dadurch erzeugte Zeichenkette nur eine sehr begrenzte Entropie aufweist, denn mt_rand() erzeugt keine kryptografisch sicheren Pseudo-Zufallszahlen und wird mit einer Grösse mit einer verhältnismässig geringen Entropie (der aktuellen Systemzeit) initialisiert. Dies ist auch in der Dokumentation von mt_rand() unter http://php.net/manual/en/function.mt-rand.php vermerkt. Sofern du die OpenSSL-Erweiterung zur Verfügung hast, könntest du als Alternative http://php.net/manual/en/function.openssl-random-pseudo-bytes.php nutzen.
 

Krutius

Verrückter

Registriert
14 Juli 2013
Beiträge
115
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

nimmst du die Zeichen "äüöߧ" raus, dann klapts. Zumindest bei mir. Dürft an der Kodierung liegen.

Ich würde sowieso gemäss dem schon öfters erwähnten Artikel entweder mcrypt_create_iv oder openssl_random_pseudo_bytes verwenden, da mt_rand höchstwarscheinlich keine kryptografisch sicheren zufallszahlen liefert.

die ? dürften nur ein Problem der Ausgabe sein, und intern keine Probleme verursachen (hoffe ich). Edit: falsch, siehe Kugelfisch

edit: Zeitliche überschneidung mit Kugelfisch, seine Antwort ist auch deutlich präziser.
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #4
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

Habe jetzt nicht verstanden wo das Problem mit mt_rand() liegt.
In der PHP Dokumentation heißt es nur, dass mt_rand() besser ist als rand()

Danke für den Hinweis Krutius. Habe "äüöߧ?" rausgenommen. Passt jetzt
 

Kugelfisch

Nerd

Registriert
12 Juli 2013
Beiträge
2.342
Ort
Im Ozean
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

In der PHP Dokumentation heißt es nur, dass mt_rand() besser ist als rand()
Das Problem (das bei der PHP-Dokumentation leider keine Seltenheit ist) ist die unvollständige Übersetzung der englischsprachigen Original-Dokumentation, welche den folgenden Warnhinweis enthält:
This function does not generate cryptographically secure values, and should not be used for cryptographic purposes. If you need a cryptographically secure value, consider using openssl_random_pseudo_bytes() instead.
Ob das ein Problem ist, hängt vom konkreten Anwendungsfall ab. Für ein Hash-Salt, das keine geheimzuhaltende Information ist, mag es u.U. ausreichen, für kryptografisches Schlüsselmaterial mit Sicherheit nicht. Die von mt_rand() erzeugten Zufallszahlenfolgen sind bis zu einem gewissen Grad vorhersagbar, da als einzige Entropiequelle die Systemzeit verwendet wird, die zudem leicht vorhersagbar ist.
 

Exterminans

Neu angemeldet

Registriert
14 Juli 2013
Beiträge
147
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

Mal davon abgesehen ist mt_rand keinesfalls uneingeschränkt besser. Der Unterschied ist, aus welcher Bibliothek der jeweilige Algorithmus stammt.

mt_rand basiert auf dem Mersenne-Twister und ist Teil der PHP-eigenen Bibliotheken.
rand hingegen ist die rand-Funktion aus der libc, sprich die Qualität hängt sehr stark davon ab, welcher Algorithmus jeweils in der installierten libc-Version verwendet wird. Da gab es in der Vergangenheit teilweise Probleme, die sind aber nicht mehr wirklich aktuell. Aktuell ist der Mersenne-Twister sogar eher langsamer und liefert trotzdem tendenziell eine "weniger zufällige" Verteilung bei großen Zahlen.
 

Cyperfriend

Der ohne Avatar

Registriert
14 Juli 2013
Beiträge
1.123
  • Thread Starter Thread Starter
  • #7
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

Aber um einen Salt zu erzeugen sollte das doch ausreichen oder muss ich mich weiter verkünsteln?
 

Kugelfisch

Nerd

Registriert
12 Juli 2013
Beiträge
2.342
Ort
Im Ozean
Re: [PHP] Zufällige Zahlen / Buchstaben / Sonderzeichenkombination macht Probleme

Für die rein interne Verwendung als Salt-Hash reicht deine Methode meines Erachtens zwar aus, zumindest sehe ich keinen konkreten Angriffspunkt. Sofern du allerdings die OpenSSL-Erweiterung ohnehin zur Verfügung hast, sehe ich keinen Grund, nicht openssl_random_pseudo_bytes zu nutzen - das wäre in deinem Fall sogar simpler, um eine Zeichenkette bestehend aus 100 zufälligen Bytes zu erzeugen, reicht:
PHP:
$salt = openssl_random_pseudo_bytes(100);
Beachte, dass die Bytes tatsächlich zufällig sind, also auch nicht-druckbare Zeichen enthalten können. Für die Berechnung des Hashs ist das kein Problem, vor dem Speichern in eine Text-Spalte einer Tabelle solltest du den Salt jedoch Base64-kodieren (base64_encode()).
 
Oben