Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-06-2012, 15:14   #1
legolas93
Senior Member
 
Iscritto dal: Dec 2007
Messaggi: 659
[JAVA] Crittografia e Salvataggio Chiave

Ciao ragazzi. Sto sperimentando con la crittografia e in particolare con l'algoritmo AES. Ho un programma completamente funzionante che deve salvare un file di testo crittografato per poi poterlo riaprire alla successiva apertura.

Io vorrei che tutto ciò avvenisse in modo trasparente all'utilizzatore. Solo io so la chiave (io programmatore..) però non voglio altresì doverla inserire a mano ad ogni apertura.

In questi casi solitamente cosa si fa?..Dove la si salva la chiave?..

In un file di testo in chiaro direi che è da escludere a priori..

Mmm..come variabile statica all'interno del programma? E' sicuro come metodo?

Sono proprio nuovo di questo campo e ogni consiglio è ben accetto.
legolas93 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2012, 18:44   #2
U-Boat
Member
 
Iscritto dal: Dec 2001
Città: Cernobbio -Co-
Messaggi: 47
Non ne vieni fuori facilmente, quindi devi decidere a che livello di sicurezza punti, insomma capire da chi ti devi "difendere" (se la risposta è "nessuno" non serve nemmeno cifrare il file se ci pensi) e come è fatto il tuo sistema.

Da quello che capisco ti stai ponendo un problema più teorico che pratico e stiamo parlando di un'applicazione che sta completamente sul tuo pc insieme al file di testo cifrato, quindi parlo in termini un po' generali per inquadrare il problema.

Idealmente la chiave dovrebbe essere nascosta, modificabile dall'utente e ignota al programmatore dell'applicativo.

Salvare la chiave nel codice ha diversi problemi:
- non puoi cambiarla
- la chiave sarà la stessa per ogni copia del tuo applicativo
- tu conosci la chiave
- decompilando il codice la trovi (specialmente in Java questa è un'operazione piuttosto semplice)

Se la salvi su un file rimane a "vista", ma almeno puoi cambiarla facilmente.
Puoi pensare di salvarla in un file nascosto da qualche o nel registro di Windows, ma anche qui in qualche modo si può trovare.
Puoi pensare di cifrarla a sua volta, ma a quel punto il problema si sposta a dove tenere la chiave di cifratura della chiave e torni all'inizio del problema.

Una soluzione è quella di "fidarsi" del sistema sottostante, ad esempio puoi impostare i diritti di lettura del file solo alla tua applicazione, cosa che funziona se l'utente non è amministratore.

Insomma, se pensi che l'attaccante possa essere direttamente sulla tua macchina con diritti di amministratore non ne vieni fuori. A volte questi vincoli non sono così importanti, mi viene in mente un sistema di allarme, la cui centralina viene messa nel punto più sicuro e meno raggiungibile della casa: se un ladro è riuscito ad arrivare lì, probabilmente il buco di sicurezza è a monte

Ti faccio notare che in realtà il tuo problema vero è all'inizio: se cifri un file e in qualche modo salvi la chiave perchè non sia necessario reinseirla, anche se usi un metodo totalmente sicuro sarà sufficiente lanciare il tuo applicativo per vedere il testo in chiaro... insomma, non ti serve a nulla
__________________
micheledellatorre.net
U-Boat è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2012, 22:11   #3
legolas93
Senior Member
 
Iscritto dal: Dec 2007
Messaggi: 659
Quote:
Originariamente inviato da U-Boat Guarda i messaggi
Non ne vieni fuori facilmente, quindi devi decidere a che livello di sicurezza punti, insomma capire da chi ti devi "difendere" (se la risposta è "nessuno" non serve nemmeno cifrare il file se ci pensi) e come è fatto il tuo sistema.

Da quello che capisco ti stai ponendo un problema più teorico che pratico e stiamo parlando di un'applicazione che sta completamente sul tuo pc insieme al file di testo cifrato, quindi parlo in termini un po' generali per inquadrare il problema.

Idealmente la chiave dovrebbe essere nascosta, modificabile dall'utente e ignota al programmatore dell'applicativo.

Salvare la chiave nel codice ha diversi problemi:
- non puoi cambiarla
- la chiave sarà la stessa per ogni copia del tuo applicativo
- tu conosci la chiave
- decompilando il codice la trovi (specialmente in Java questa è un'operazione piuttosto semplice)

Se la salvi su un file rimane a "vista", ma almeno puoi cambiarla facilmente.
Puoi pensare di salvarla in un file nascosto da qualche o nel registro di Windows, ma anche qui in qualche modo si può trovare.
Puoi pensare di cifrarla a sua volta, ma a quel punto il problema si sposta a dove tenere la chiave di cifratura della chiave e torni all'inizio del problema.

Una soluzione è quella di "fidarsi" del sistema sottostante, ad esempio puoi impostare i diritti di lettura del file solo alla tua applicazione, cosa che funziona se l'utente non è amministratore.

Insomma, se pensi che l'attaccante possa essere direttamente sulla tua macchina con diritti di amministratore non ne vieni fuori. A volte questi vincoli non sono così importanti, mi viene in mente un sistema di allarme, la cui centralina viene messa nel punto più sicuro e meno raggiungibile della casa: se un ladro è riuscito ad arrivare lì, probabilmente il buco di sicurezza è a monte

Ti faccio notare che in realtà il tuo problema vero è all'inizio: se cifri un file e in qualche modo salvi la chiave perchè non sia necessario reinseirla, anche se usi un metodo totalmente sicuro sarà sufficiente lanciare il tuo applicativo per vedere il testo in chiaro... insomma, non ti serve a nulla
Cavolo..mi hai aperto un mondo! Grazie Mille! Non sapevo fosse così semplice recuperare il codice sorgente dal Bytecode ..ora mi sono messo per un attimo nei panni di qualcuno che vuole vendere un applicativo in Java come fa a proteggersi da chi vuole rubare il suo codice?

Mentre per quanto riguarda la mia domanda mi sa che farò in modo che sia direttamente l'utente ad inserire la password. Penso sia la cosa più sicura.. (Adesso riposo e tento di chiarirmi le idee su cosa voglio fare veramente ).

PS: Sarei veramente grato a chiunque abbia qualche informazione in più riguardo al primo punto di questa risposta..furto di codice ecc..

Grazie
legolas93 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2012, 23:59   #4
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Quote:
Originariamente inviato da legolas93 Guarda i messaggi
..ora mi sono messo per un attimo nei panni di qualcuno che vuole vendere un applicativo in Java come fa a proteggersi da chi vuole rubare il suo codice?
Esistono degli offuscatori di codice che rendono molto più difficile il reverse engineering... Cambiano i nomi delle variabili, dei metodi e cose di questo tipo per rendere il processo molto più lungo e complesso.
__________________
Non c'è cosa peggiore nella vita di un programmatore di un errore che si presenta solo ogni tanto.

CONCLUSO POSITIVAMENTE CON: oldfield
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
Le fotografie dell'eclissi solare e dell...
Oracle AI Database si potenzia con nuove...
Russia offline: blackout internet mobile...
Gemini, Google investe 30 milioni per la...
Roborock Qrevo Edge S5A: 17.000 Pa, acqu...
Resa pubblica la foto della ''Terra che ...
Il robot che ha piegato 200 scatole di f...
SteelSeries Aerox 3 Wireless Gen 2: nuov...
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
Tomodachi Life non supporterà Handheld M...
Identificati i boss di REvil e GandCrab:...
Google Chrome 148 introduce il caricamen...
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: 18:23.


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