| 
 | |||||||
| 
 | 
|  | 
|  | 
|  | Strumenti | 
|  01-03-2005, 19:10 | #1 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
				
				(JAVA) generare password
			 
		classe: Codice: import java.util.*;
public class PwdGenerator {
    
    /** Creates a new instance of GeneratePwd */
    public PwdGenerator() {
           
    }
    
	Random rnd = new Random();
	
	public static void main(String arfgv[])
	{
		PwdGenerator a = new PwdGenerator();
		System.out.println(a.getPWD());
                PwdGenerator a2 = new PwdGenerator();
		System.out.println(a2.getPWD());
	}
    public String getPWD() {
        
        //decido dimensione password
        int dim = 8;//rnd.nextInt(5);
        //dim = dim+6;
        //decido la quantità di cifre numeriche
        int num = rnd.nextInt(dim-4)+1;
        num= num+2;
        //decido la quantità di cifre alfa
        int alfa = dim-num;
        int appoggio=0;
        String pass="";
        int alterna=0;
        int contnum=1;
        int contalfa=1;
        for (int i=1;i<=dim;i++) {
            alterna = rnd.nextInt(2);
            if (contalfa>alfa){alterna=0;}
            else{if (contnum>num) {alterna=1;}
            }
            if (alterna==1) {contalfa++;
            appoggio = rnd.nextInt(25);
            switch (appoggio) {
                case 0 : pass = pass+"A";break;
                case 1 : pass = pass+"B";break;
                case 2 : pass = pass+"C";break;
                case 3 : pass = pass+"D";break;
                case 4 : pass = pass+"E";break;
                case 5 : pass = pass+"F";break;
                case 6 : pass = pass+"G";break;
                case 7 : pass = pass+"H";break;
                case 8 : pass = pass+"I";break;
                case 9 : pass = pass+"J";break;
                case 10 : pass = pass+"K";break;
                case 11 : pass = pass+"L";break;
                case 12 : pass = pass+"M";break;
                case 13 : pass = pass+"N";break;
                case 14 : pass = pass+"O";break;
                case 15 : pass = pass+"P";break;
                case 16 : pass = pass+"Q";break;
                case 17 : pass = pass+"R";break;
                case 18 : pass = pass+"S";break;
                case 19 : pass = pass+"T";break;
                case 20 : pass = pass+"U";break;
                case 21 : pass = pass+"W";break;
                case 22 : pass = pass+"X";break;
                case 23 : pass = pass+"Y";break;
                case 24 : pass = pass+"Z";break;
            }
            }
            if (alterna==0) {contnum++;
            appoggio = rnd.nextInt(10);
            switch (appoggio) {
                case 0 : pass = pass+"0";break;
                case 1 : pass = pass+"1";break;
                case 2 : pass = pass+"2";break;
                case 3 : pass = pass+"3";break;
                case 4 : pass = pass+"4";break;
                case 5 : pass = pass+"5";break;
                case 6 : pass = pass+"6";break;
                case 7 : pass = pass+"7";break;
                case 8 : pass = pass+"8";break;
                case 9 : pass = pass+"9";break;
            }
            }
        }
        
        return pass;
    }
    
}PwdGenerator a = new PwdGenerator(); String pws =a.getPWD(); Io penso che se la pagina che contiene la creazione della password viene richiamata contemporaneamente da 2 utenti(unpo' come avviene nel main che ho mostrato) le password generate sono uguali(per via delle caratteristiche della classe Random ) La mia paura è fondata o si tratta di un'ipotesi semimpossibile? Come si puo' rimediare? ciao grazie Ultima modifica di prazision : 01-03-2005 alle 19:24. | 
|   |   | 
|  01-03-2005, 22:55 | #2 | |
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | 
				
				Re: (JAVA) generare password
			 Quote: 
 statisticamente è molto difficile, ma se vuoi rimediare in maniera molto semplice basta che usi la stessa istanza di Random per generare tutti i numeri casuali usati da PwdGenerator. | |
|   |   | 
|  01-03-2005, 23:13 | #3 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		ok grazie ma come faccio, con static??
		 | 
|   |   | 
|  01-03-2005, 23:16 | #4 | |
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | Quote: 
 esatto. per non incorrere in problemi di concorrenza non dovresti pero' accedere direttamente all'oggetto ma farlo attraverso un metodo sincronizzato della tua classe, in modo che le richieste siano sequenziali. | |
|   |   | 
|  01-03-2005, 23:18 | #5 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		tramite l'uso della classe Thread vero???(l'avevo visto qualche esempio)
		 | 
|   |   | 
|  01-03-2005, 23:30 | #6 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		(forse la classe Thread non centra nulla)
		 | 
|   |   | 
|  02-03-2005, 09:20 | #7 | 
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | 
		no lascia stare i thread, ti dichiari un getPwd() synchronized e solo lì accedi all'oggetto di classe Random condiviso tra tutte le istanza della tua classe. Lo scopo è proprio quello di evitare di chiamare nextInt() da due thread contemporaneamente. | 
|   |   | 
|  02-03-2005, 10:03 | #8 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		ok grazie, se avro' problemi ti scassero'    | 
|   |   | 
|  02-03-2005, 14:01 | #9 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		Ho notato che se metto static Random rnd = new Random(); invece di Random rnd = new Random(); e utilizzo un metodo static cosi: public static void main(String arfgv[]) { PwdGenerator a = new PwdGenerator(); System.out.println(a.getPWD()); PwdGenerator a2 = new PwdGenerator(); System.out.println(a2.getPWD()); } ottengo 2 password diverse (al contrario di quando rnd non è static) Perchè succede questo? se le chiamate sono istantanee il seme di Random non dovrebbe essere cmq lo stesso?? Forse perchè l'oggetto rnd è condiviso dalle classi istanziate e quindi il metodo nextInt() viene eseguito dallo stesso oggetto(e quindi per forza in maniera sequenziale, dando 2 risultati diversi)? E quindi tale cosa potrebbe risolvere il mio problema nel senso che anche se ci fossero 2 chiamate a 2 pagine nello stesso istante la password generate sarebbero diverse(unpo' come nel main della mia classe)? spero di essermi spiegato grazie | 
|   |   | 
|  02-03-2005, 14:51 | #10 | 
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | 
		ma scusa di che stavamo parlando?   la "new" viene eseguita solo la prima volta che la classe viene istanziata, per cui la seconda opera sulla stessa istanza e quindi nextInt() richiama un nuumero successivo nella sequenza pseudocasuale e non è mai uguale al precedente (salvo che ci siano due numeri uguali nella sequenza naturalmente) | 
|   |   | 
|  02-03-2005, 15:03 | #11 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		ma tu parlavi di synchronized , come ho fatto io(aggiungendo solo Static) non è sufficiente? inoltre ti chiedo:"nextInt() richiama un nuumero successivo nella sequenza pseudocasuale" perchè viene eseguito dallo stesso oggetto(anche se magari richiamato nello stesso isstante)? siam sicuri che non ci sono pericoli??? grazie | 
|   |   | 
|  02-03-2005, 15:07 | #12 | ||
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | Quote: 
 Quote: 
 io ti ho detto di metterlo static ma di non accedere a esso direttamente ma tramite un metodo synchronized, per prevenire possibili comportamenti anomali, se piu' thread accedessero contemporaneamente.  "nextInt() richiama un nuumero successivo nella sequenza pseudocasuale" perchè viene eseguito SULLO stesso oggetto | ||
|   |   | 
|  02-03-2005, 15:14 | #13 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		azz i metodi synchronized non li ho ancora manco visti. dici che è una cosa obbligatoria usarlo o vabene anche cosi???   | 
|   |   | 
|  02-03-2005, 15:26 | #14 | |
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | Quote: 
 non so se va bene anche così o meno perchè bisognerebbe andare a vedere il codice di java.util.Random, ma dubito che sia thread safe di suo  basta che nella tua classe crei un metodo Codice: protected synchronized int nextInt()
{
return rnd.nextInt();
}e poi al posto di chiamare rnd.nextInt() chiami questo. | |
|   |   | 
|  02-03-2005, 15:32 | #15 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		ok provero' e poi ti faro' sapere grazie | 
|   |   | 
|  02-03-2005, 16:23 | #16 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		penso che vada bene anche senza crearsi un metodo apposta synchronized  http://java.sun.com/j2se/1.4.2/docs/...m.html#nextInt(int) | 
|   |   | 
|  02-03-2005, 16:35 | #17 | |
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | Quote: 
 dove sta scritto che è thread safe?   | |
|   |   | 
|  02-03-2005, 16:48 | #18 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		dopo ci guardo bene(confesso che mi è stato detto, non ho approfondito   ) | 
|   |   | 
|  02-03-2005, 16:57 | #19 | |
| Senior Member Iscritto dal: Jan 2001 Città: Milano 
					Messaggi: 5707
				 | Quote: 
 ok, la risposta che mi hai mandato mi hai convinto. in effetti avevo guardato il sorgente di Random del jdk 1.5 e il fatto che next() non fosse synchronized mi aveva fatto "rizzare le antenne" ma PGI qui non si fa piu' vedere? | |
|   |   | 
|  02-03-2005, 17:03 | #20 | 
| Senior Member Iscritto dal: Dec 2003 
					Messaggi: 458
				 | 
		non so,non ci ho mai fatto caso. cmq non volevo fare il rompi*****, ti ringrazio tantissimo | 
|   |   | 
|   | 
| Strumenti | |
| 
 | 
 | 
Tutti gli orari sono GMT +1. Ora sono le: 08:52.









 
		 
		 
		 
		







 
  
 



 
                        
                        










