SELFPHP: Version 5.8.2 Befehlsreferenz - Tutorial – Kochbuch – Forum für PHP Einsteiger und professionelle Entwickler

SELFPHP


Professional CronJob-Service

Suche



CronJob-Service    
bei SELFPHP mit ...



 + minütlichen Aufrufen
 + eigenem Crontab Eintrag
 + unbegrenzten CronJobs
 + Statistiken
 + Beispielaufrufen
 + Control-Bereich

Führen Sie mit den CronJobs von SELFPHP zeitgesteuert Programme auf Ihrem Server aus. Weitere Infos



:: Buchempfehlung ::

Websites optimieren für Google & Co.

Websites optimieren für Google & Co. zur Buchempfehlung
 

:: Anbieterverzeichnis ::

Globale Branchen

Informieren Sie sich über ausgewählte Unternehmen im Anbieterverzeichnis von SELFPHP  

 

:: Newsletter ::

Abonnieren Sie hier den kostenlosen SELFPHP Newsletter!

Vorname: 
Name:
E-Mail:
 
 

Zurück   PHP Forum > SELFPHP > PHP Entwicklung und Softwaredesign
Hilfe Community Kalender Heutige Beiträge Suchen

PHP Entwicklung und Softwaredesign Hier können strukturelle (Programmier-) Konzepte diskutiert und Projekte vorgestellt werden

Antwort
 
Themen-Optionen Ansicht
  #11  
Alt 04.01.2010, 15:56:51
DokuLeseHemmung DokuLeseHemmung ist offline
SELFPHP Experte
 
Registriert seit: Jun 2008
Alter: 16
Beiträge: 2.269
AW: CreateRandomCode()

Zitat:
Zitat von feuervogel Beitrag anzeigen
das ist doch alles...nicht so richtig sinnvoll.

warum shuffle mehrmals aufrufen? eimal reicht doch völlig und dann mit array_slice ein stück rausschneiden.
Dann gibts aber keine Doppelten....

PHP-Code:
function createRandomCode($num

    
$array=array('','a','A','b','B','c','C','d','D','e','E','f','F'
                 
'3','4','5','6','7','8','9','0','-','_'); 
    
$code=''
    for(;
strlen($code)<$num;$code.=$array[array_rand($array)]); 
    return 
$code

Mit Zitat antworten
  #12  
Alt 05.01.2010, 23:01:01
hmp hmp ist offline
Anfänger
 
Registriert seit: Oct 2008
Alter: 36
Beiträge: 26
AW: CreateRandomCode()

Zitat:
Zitat von DokuLeseHemmung Beitrag anzeigen
Dann gibts aber keine Doppelten....

PHP-Code:
function createRandomCode($num

    
$array=array('','a','A','b','B','c','C','d','D','e','E','f','F'
                 
'3','4','5','6','7','8','9','0','-','_'); 
    
$code=''
    for(;
strlen($code)<$num;$code.=$array[array_rand($array)]); 
    return 
$code

Ist der besser, schneller oder zuverlässiger als mein Code? Interessiert mich halt, weil ich sehr daran interessiert bin meinen Code zu verbessern. Demnächst kommen noch andere schwierigere Code-Schnipsel :P. Geht einfach darum, dass das für mich eine Art Lernprozess ist. Ich denke das ich so am meisten und am besten lerne :)
Mit Zitat antworten
  #13  
Alt 05.01.2010, 23:02:44
Benutzerbild von Domi
Domi Domi ist offline
Senior Member
 
Registriert seit: Nov 2003
Ort: Kempten @ Allgäu
Alter: 36
Beiträge: 1.408
AW: CreateRandomCode()

wusstest du, dass du die zeit messen kannst? du könntest in ner for-Schleife einfach mal 10.000 Codes erstellen lassen und die Zeit messen was schnell und langsam ist, aber das hängt immer je nach Hardware ab ^^
__________________

the best way to be ready for the future is to invent it
Mit Zitat antworten
  #14  
Alt 05.01.2010, 23:11:15
DokuLeseHemmung DokuLeseHemmung ist offline
SELFPHP Experte
 
Registriert seit: Jun 2008
Alter: 16
Beiträge: 2.269
AW: CreateRandomCode()

Zitat:
Zitat von hmp Beitrag anzeigen
Ist der besser, schneller oder zuverlässiger als mein Code? Interessiert mich halt, weil ich sehr daran interessiert bin meinen Code zu verbessern. Demnächst kommen noch andere schwierigere Code-Schnipsel :P. Geht einfach darum, dass das für mich eine Art Lernprozess ist. Ich denke das ich so am meisten und am besten lerne :)
Natürlich ist mein Code schöner als der aus deinem Eingangsposting!
Denn du durchläufst mit Foreach das Array.
Das ist völlig Sinn frei.
Aber eine Schleife muss schon sein....

Hier mal ein Code welcher dank Pseudosilben leicht zu merkende Passwörter generiert.
Die dürfen dann auch etwas länger sein.
PHP-Code:
<?php
error_reporting
(E_ALL); 
ini_set('display_errors'TRUE);

// gen_passwort erzeugt automatisch passwörter
function gen_passwort($buchstaben=0,$zahlen=0)
{
  
$buchstaben max(0,$buchstaben);
  
$zahlen     max(0,$zahlen);
  if(
=== $buchstaben && === $zahlen)
  { 
// dann gib dem Zufall eine Chance
    
$buchstaben mt_rand(5,8); // anzahl Buchstaben
    
$zahlen     mt_rand(3,5); // anzahl Zahlen
  
}
  
$konsonanten ='wrtzpsdfghklyxcvbnm';
  
$vokale='aeiou';
  
$passwort '';
  for (
$i=0;$i<$buchstaben;$i++)
  {
    if ((
$i 2)<1)
    {
      
$p mt_rand(0,strlen($konsonanten)-1);
      
$bst $konsonanten{$p};
      if(
mt_rand(0,1)>0$bst strtoupper($bst);
      
$passwort .= $bst;
    }else
    {
      
$p mt_rand(0,strlen($vokale)-1);
      
$passwort .= $vokale{$p};
    }
  }
  for (
$i=0;$i<$zahlen;$i++) $passwort .= mt_rand(1,9);
  return  
$passwort;
}


if(isset(
$_GET['action']) && 'download' === $_GET['action'])
{
    
header("Content-type: application/x-applikation");
    
readfile(__FILE__);
    exit;
}
if(isset(
$_GET['action']) && 'showsource' === $_GET['action'])
{
    
highlight_file(__FILE__); 
    exit;
}

if (isset(
$_POST['submit']))
{
   
$buchstaben  min(40,$_POST['buchstaben']);
   
$zahlen      min(40,$_POST['zahlen']);
   
$anzahl      min(40,max($_POST['anzahl'],1));
}else
{
  
$buchstaben 0;
  
$zahlen     0;
  
$anzahl     10;
}
?>
<a href="?action=download">Download</a>  ||  
<a href="?action=showsource">ShowSource</a>
<hr>
<form action="" method="post">
Buchstaben:<br>
<input type="text" name="buchstaben" value="<?php echo $buchstaben?>"><br><br>
Zahlen:<br>
<input type="text" name="zahlen" value="<?php echo $zahlen?>"><br><br>
Anzahl:<br>
<input type="text" name="anzahl" value="<?php echo $anzahl?>"><br><br>
<br>
<input type="submit" name="submit" value="Generieren">
</form>

<?php

// ausgabe
for ($i=0;$i<$anzahl;$i++) 
{
  echo 
gen_passwort($buchstaben,$zahlen).'<br>';
}  
?>
Mit Zitat antworten
  #15  
Alt 02.06.2010, 21:31:53
1-1-1 1-1-1 ist offline
Anfänger
 
Registriert seit: May 2010
Ort: München
Alter: 68
Beiträge: 5
AW: CreateRandomCode()

Anfang:
AaBbCcDdEe FfGgHhiJKk LMmNnoPpQq RrSsTtUuVv WwXxYyZz12 3456789
=> 57 gültige Zeichen
Keine Verwechslungsgefahr (kleines o aber keine Null oder großes O usw.) funktioniert seit Jahren wunderbar.
57 ist eine schöne runde Primzahl.
In acht Zeichen passt eine IP oder ein Timestamp rein.
Du brauchst eine geile Zufallszahl? Schau Dir mal den Quelltext (erste Zeile) einer Google-Abfrage an!
Mit Zitat antworten
  #16  
Alt 13.07.2010, 13:55:13
tewe tewe ist offline
Anfänger
 
Registriert seit: Aug 2008
Alter: 40
Beiträge: 21
AW: CreateRandomCode()

Zitat:
Zitat von 1-1-1 Beitrag anzeigen
57 ist eine schöne runde Primzahl.
Damit stellst du ca 2300 Jahre Mathematik auf den Kopf... :D
Mit Zitat antworten
  #17  
Alt 14.07.2010, 11:13:42
DokuLeseHemmung DokuLeseHemmung ist offline
SELFPHP Experte
 
Registriert seit: Jun 2008
Alter: 16
Beiträge: 2.269
AW: CreateRandomCode()

Bevor das hier unkritisiert stehen bleibt:
PHP-Code:
 $code.=end(shuffle($array)); 
end() erwartet ein Array.
shuffle() liefert aber keins.

Aus dem Handbuch:
Zitat:
mixed end ( array &$array )
bool shuffle ( array &$array )
Mit Zitat antworten
Antwort


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind aus.
[IMG] Code ist aus.
HTML-Code ist aus.

Gehe zu


Alle Zeitangaben in WEZ +2. Es ist jetzt 02:04:50 Uhr.


Powered by vBulletin® Version 3.8.3 (Deutsch)
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.


© 2001-2024 E-Mail SELFPHP OHG, info@selfphp.deImpressumKontakt