Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-01-2008, 09:58   #1
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
[JAVA] RMI, come autenticare gli utenti?

Salve a tutti.

Avendo un'applicazione distribuita multiutente, come riconosco l'utente
che sta effettuando la chiamata?

Ad esempio, se un client chiama un metodo tipo changePassword(...),
il server deve conoscere l'utente di cui cambiare la password.

Io avevo pensato di avere un server per ogni utente autenticato,
oppure di riconoscere l'host del client tramite RemoteServer.getClientHost(),
ma se ci sono più utenti nello stesso host?

Potrei forse intervenire sulle socket factory?

Grazie
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 10:25   #2
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Mi rispondo da solo:
con RMI si possono esportare più server sulla stessa porta,
quindi mi sa che creerò 1 server per ogni utente.

Grazie lo stesso
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 10:50   #3
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
ehmm..
ma passare la stringa dell'username nel metodo changePassword?
qualcosa del tipo:
Codice:
superServerPippone.changePassword("MyUser", "NewPassword");
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 10:54   #4
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Sì, ma se l'utente tizio chiama:

superServerPippone.changePassword("caio","asdfg");

lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 11:52   #5
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da lovaz Guarda i messaggi
Sì, ma se l'utente tizio chiama:

superServerPippone.changePassword("caio","asdfg");

e se fai
Codice:
superServerPippone.changePassword(SHA("tizio","password attuale"),"pollo")
??

Tecnicamente solo tizio sa calcolare la firma hash con sha di <user,passwordAttuale>. (è la prima tecnica di autenticazione che mi è venuta in mente, se mi ci impegno potrei trovarne di migliori)
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 13:40   #6
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originariamente inviato da morskott Guarda i messaggi

Tecnicamente solo tizio sa calcolare la firma hash con sha di <user,passwordAttuale>. (è la prima tecnica di autenticazione che mi è venuta in mente, se mi ci impegno potrei trovarne di migliori)
se non gli passi l'utente come fa il server a sapere di chi deve cambiare la password?
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 17:49   #7
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da kingv Guarda i messaggi
se non gli passi l'utente come fa il server a sapere di chi deve cambiare la password?
Semplice, scanna tutti gli user registrati fino a trovare quello giusto (oppure la cambia ad uno random )

Scherzi a parte basta passarglielo nel metodo (che rimane sicuro perchè l'hash lo sa calcolare solo l'utente legittimo), tecnicamente sarebbe passibile di attacco di replay, ma visto che è un metodo di cambio password la vecchia password non sarà piu valida dopo l'invocazione
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 18:23   #8
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Sì, ma mi interessa conoscere l'utente non solo per il cambio password,
ma ad esempio anche per transazioni finanziarie tipo
diminuisci/aumenta credito, ecc.

Praticamente un'autenticazione per ogni chiamata.

Vedrò, intanto mi studio le socket factory ssl, alla prossima...
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2008, 20:22   #9
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da lovaz Guarda i messaggi
Sì, ma mi interessa conoscere l'utente non solo per il cambio password,
ma ad esempio anche per transazioni finanziarie tipo
diminuisci/aumenta credito, ecc.

Praticamente un'autenticazione per ogni chiamata.

Vedrò, intanto mi studio le socket factory ssl, alla prossima...
Allora puoi fare tipo kerberos (versione semplificata e adattata allo scopo), puoi creare un "Biglietto" che alla prima autenticazione del client col server il client se lo tiene per tutta la sessione e che deve esser presentato ad ogni richiesta che farà in futuro, qualcosa tipo
Codice:
public class Biglietto{
private String user;
private TimeStamp timeToLive //TimeStamp sarà una classe che dice per quanto tempo il biglietto è valido
private String server;
private String fingerPrint;

//costruttori etc. etc.
}
e ogni chiamata del client al server sarà del tipo[code]Biglietto b=//biglietto ottenuto all'autenticazione
sever.doSomeWork(b,//altri parametri);[code], per l'autenticazione potresti utilizzare una banale sfida

Client
Codice:
String sfidaDalServer=server.primoPassoAutentica("sonoAlice");
Biglietto b=server.secondoPassoAutentica(calcolaHash(sfidaDalServer,miaPassword));
Il server alla richiesta "primoPassoAutentica" dovrà generare una stringa completamente casuale (ovviamente diversa ad ogni nuova invocazione del primo passo) e calcolare e memorizzare l'hash della sfida che ha mandato e della pass dell'utente, e alla seconda fase il server controlla che l'hash che gli dai sia uguale a quello che si è calcolato lui.
Attenzione che così il server autentica il client, ma il client non è sicuro di parlare col server, per quello ci vorrebbe una autentica a 2/3 direzioni.

Il server avrà un insieme di biglietti validi e ad ogni richiesta del client controlla prima di tutto se il biglietto è valido (tramite confronto con la sua tabella), e poi l'utente che richiede servizio.
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB

Ultima modifica di morskott : 24-01-2008 alle 20:25.
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2008, 08:34   #10
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da morskott Guarda i messaggi
Semplice, scanna tutti gli user registrati fino a trovare quello giusto...
(poverini... )
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2008, 14:38   #11
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
(poverini... )
la dura vita degli utenti......
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2008, 10:41   #12
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Quote:
Originariamente inviato da morskott Guarda i messaggi
... per l'autenticazione potresti utilizzare una banale sfida
...
Attenzione che così il server autentica il client, ma il client non è sicuro di parlare col server, per quello ci vorrebbe una autentica a 2/3 direzioni.
...
Infatti alla prima autenticazione faccio così, una getChallenge() e una
sendResponse(), che ritorna un riferimento al server (oggetto remoto)
creato ad hoc per l'utente, che fa quindi le veci del biglietto...
ogni chiamata remota è come se avesse come parametro (nascosto)
il server a cui è diretta.

Poi potrei anche usare le socket factory SSL con autenticazione del client,
ho visto che le modifiche al codice sono minime, il grosso è la generazione
delle keystore/truststore.

Sto facendo delle prove, mi rifaccio vivo fra qualche giorno.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2008, 12:24   #13
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da lovaz Guarda i messaggi
Infatti alla prima autenticazione faccio così, una getChallenge() e una
sendResponse(), che ritorna un riferimento al server (oggetto remoto)
creato ad hoc per l'utente, che fa quindi le veci del biglietto...
ogni chiamata remota è come se avesse come parametro (nascosto)
il server a cui è diretta.

Poi potrei anche usare le socket factory SSL con autenticazione del client,
ho visto che le modifiche al codice sono minime, il grosso è la generazione
delle keystore/truststore.

Sto facendo delle prove, mi rifaccio vivo fra qualche giorno.
Oppure, sempre con l'idea della classe "Biglietto" potresti fare questo schema

U->S: sono Alice
S->U: N (il server invia all'utente un nonce (stringa casuale sempre diversa))
U->S: N',H(N,N',S,K)
S->U: H(N,N',K)

doce con K ho indicato la password e con H(..) la funzione di hash, così sono mutuamente autenticati
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2008, 12:27   #14
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
N' e S cosa sono?
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2008, 18:59   #15
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Quote:
Originariamente inviato da lovaz Guarda i messaggi
N' e S cosa sono?
N' è un secondo nonce diverso da N e S la stringa che identifica il Server
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB
morskott è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Anche Cloudflare fissa il 2029 per la si...
Hacker sfruttano da mesi un bug segreto ...
ASUSTOR Lockerstor 24R Pro Gen2: 24 bay ...
Rigetti supera la soglia dei 100 qubit: ...
eFootball raggiunge il miliardo di downl...
Come provare OpenClaw facilmente grazie ...
Microsoft conferma: questo glitch dell'o...
Toyota bZ7: una berlina da oltre 5 metri...
Artemis II, le prime foto del lato nasco...
Sempre più pubblicità su YouTube: arriva...
Polestar fa +80% in Italia e tocca quota...
Il tuo Mac smette di connettersi a Inter...
La nuova alleanza Intel-Google ridefinis...
Energia troppo cara, regole da rivedere:...
CPU che si piegano e miglior contatto: I...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 17:33.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v