|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
[security] off-line temporary permissions
Ciao,
dovendo sviluppare un sistema di sicurezza che conceda diritti di accesso a dati locali (ad esempio contenuti nel disco fisso della macchina in cui gira l'applicazione in questione) per un tempo limitato, ho il problema di come rilevare se tale tempo sia trascorso. Potrei semplicemente verificare la data di concessione e la data attuale, ma come evitare attacchi che prevedano la modifica della data di sistema? Il problema nasce dal fatto che non posso verificare la data attuale chiedendola a un server remoto: il sistema deve funzionare off-line. avete dei consigli o dei riferimenti a qualche documento che tratta l'argomento? In sostanza, il problema è analogo a quello di una versione trial di un applicativo che scada dopo N giorni. grazie mille per l'aiuto |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ma la tua applicazione è sempre in esecuzione o va in esecuzione solo quando vuole l'utente ?
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
una versione trial di un software (che ne so? Visual Studio, per esempio) come gestisce l'autorizzazione temporanea al suo utilizzo?
mi bastano anche dei consigli per delle chiavi di ricerca per cercare info su google |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
L'unico modo è pararti il sedere sulla modifica dell'ora.
Al momento in cui esegui il tuo programma controlla la data di ultima modifica di un file del tuo programma, se l'ultima modifica è antecedente alla data attuale supponi che sia tutto corretto. Se è precedente fai scadere il programma Se è tutto ok memorizza la data corrente. Tieni il conto del tempo tramite un timer (un evento al minuto), se alla chiusura l'orologio di sistema risulta essere più indietro (facciamo di più di 5 minuti) rispetto a quello che dovrebbe essere secondo il timer allora fai scadere il programma. Se è tutto corretto modifica il solito file che leggi all'inizio in modo da verificare l'ora di chiusura al prossimo riavvio. Puoi anche metterti al riparo verificando da quanto è acceso il PC, l'ora corrente deve essere maggiore del tempo dell'ultimo accesso al file del tuo programma + il tempo in cui il PC è stato acceso. Altra alternativa: fare le cose sporche. Metti un qualche programma in esecuzione automatica e verifica che sia sempre presente quando fai girare il tuo programma. In questo modo puoi conoscere la data sia di accensione che di spegnimento del PC e puoi verificare, con un timer, che l'ora corrente sia concorde con il contdown per la scadenza, se non è concorde aggiorna la data iniziale in modo che data iniziale = data corrente - tempo rimasto prima della scadenza. |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
Quote:
l'uptime non è male, ma mi vengono in mente scenari di attacco talei per cui l'applicazione riesce soltanto a calcolare il tempo totale in cui resta aperta... grazie per gli spunti!!! |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Certo, non esistono, che io sappia modi sicuri. Prima di tutto devono capire a quel file accedi
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
|
Ma a chi è destinata questa applicazione?
Se il target è l'utente "normale" allora ci sono mille modi per creare quello che vuoi (alcuni te li ha detti cionci). Se invece vuoi distribuirla solo a dei cracker allora boh...dovresti inventarti un sistema di protezione che non esiste e sia difficile da individuare... Saluti
__________________
iMac 27" 5K |
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
Quote:
|
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Puoi tenere i dati compressi con algoritmo/chiave inseriti nel tuo programma.
Cosi' nessuno innanzitutto puo' usarli se non mediante il tuo programma. Per quanto riguarda il timer, le soluzioni proposte sono resistenti. Una delle possibili pecche potrebbe essere il rallenty. Esistono programmi che modificano il timer di sistema, per allungare appunto i tempi di consultazione. Possono addirittura bloccarlo. Un'alternativa potrebbe essere quella di capire il passaggio del tempo mettendo in relazione i Megahertz della macchina, valore leggibile mediante WMI e difficilmente modificabile, con il numero di colpi di clock trascorsi a partire dall'accensione, valore restituito da una delle istruzione macchina anch'esso difficilmente modificabile. Sebbene questo metodo sia per vari motivi meno preciso di un timer serio, ritengo che possa essere sufficiente, e piu' robusto, per questo problema.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Oct 2006
Messaggi: 1105
|
Quote:
in questo momento la delivery dei contenuti è cifrata con chiave inserita nel programma (anche se questo implica che chiunque abbia accesso al programma ottiene un accesso ai dati). Il problema è che molte operazioni di navigazione dei dati prevedono la lettura di una decina di immagini da 1 MB l'una. Anche con chiavi da 128 bit, la decifrazione con l'algoritmo AES implica prestazioni insufficienti... grazie mille per l'aiuto! |
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Attenzione che i megahertz non sono affidabili in quanto non sono costanti
Credo che la soluzione migliore sia appunto far girare un'applicazione all'avvio del sistema. Nota che l'applicazione dovrebbe misurare un tempo molto vicino all'uptime di sistema in quanto è avviata con il sistema. Se trovi differenze apprezzabili togli elimini l'autorizzazione. Con la parola "timer" in precedenza mi riferivo appunto a quelli e non ad una semplice differenza di tempo |
|
|
|
|
|
#13 | |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Quote:
Pero' anche il timer si puo' cambiare. Si puo' cambiare il suo step, ovvero far incrementare il timer di sistema di 1 secondo quando invece e' trascorso 1 minuto. O almeno, io lo sapevo fare programmando l'8253 del chipset, non so se oggi e' ancora altrettando semplice.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 19:44.




















