|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
[C++] problema manipolazione ora e data corrente-urgente!
Bounasera,
devo scrivere in c++ una funzione che effettui la rappresentazione a 128 bit dell'ora e data corrente. Come posso procedere? E' piuttosto urgente perche' devo realizzare un generatore di numeri pseudocasuali basato su ANSI X9.17 che utilizza AES al posto di 3DES. Grazie mille in anticipo |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
C'è uno standard per questa rappresentazione o ti serve semplicemente un seed per avviare la generazione ?
Se è la prima...puoi inventartelo più o meno da solo. Che so...metti l'output di time() nei primi 32 bit. Metti il numero di microsecondi nei 32 bit successivi. Metti l'and e l'or fra i primi 32 bit ed i secondi 32 bit nelle altre posizioni. |
|
|
|
|
|
#3 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Devo seguire uno standard e quindi devo avere una rappresentazione a 128 bit dell'ora e data corrente!
Seguendo il tuo suggerimento potrei mettere nei primi 32 bit l'ora, nei successivi 32 bit i minuti e negli altri successivi 32 bit i secondi utilizzando mangari la struttura struct_tm?? Infine mi rimangono 32 bit per la data...ma quale funzione utlizzare???
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2780
|
Ma no scusa, così stai sprecando i bit che hai a disposizione. Che senso ha usare 32 bit per i secondi e per i minuti se poi il loro valore massimo è 60? Stesso ragionamento per le ore.
Quello che ti stava consigliando cionci credo che sia di aggiungere dei bit di controllo della correttezza. Dici che devi seguire uno standard ma l'unica cosa che ti richiede è di usare 128 bit? Sicuro che non spieghi anche come devono essere usati? |
|
|
|
|
|
#5 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Come detto prima, l'algoritmo ANSI X9.17 prevede come input una rappresentazione a 64 bit dell'ora e data corrente.
Io devo fare una modifica di questo standard, ovvero devo prendere data e ora corrente e trasformarla in una rappresentazione numerica a 128 bit dato che tale algoritmo mi deve generare una sequenza di numeri pseudocasuali. |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Quote:
Come l'hai proposta te è abbastanza inutile, primo perché all'interno di un secondo potresti avere bisogno anche di più timestamp, secondo perché hai molti bit a zero. Io se dovessi creare un seed o comunque un valore di partenza per un calcolo pseudo casuale cercherei di pienare il più possibile i 128 bit. Il modo che ti avevo suggerito era: da 0 a 31 bit = il numero di secondi trascorsi dal 1 gennaio 1970 da 32 a 63 bit = il numero di microsecondi letti dal sistema |
|
|
|
|
|
|
#7 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Scusate ma non sono esperta di C++ e quindi molte cose possono risultare inutili
Scusa in questo modo che mi consigli... la data dove sta??? L' input di partenza di ANSI 9.17 è sia un seme inizializzato in modo arbitrario sia la rappresenmtazione dell'ora e data. Ultima modifica di ARGENTOVIVO81 : 02-12-2009 alle 20:31. Motivo: chiarimento |
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
In ogni caso credo che quello che ti serve sia solamente un seed, quindi l'importante è che sia diverso ad ogni inizializzazione del generatore.
Quindi già in teoria saresti a posto semplicemente estendendo i 64 bit a 128 bit senza alcuna modifica all'algoritmo che calcola il seed. Nei restanti 64 bit potresti metterci anche un hash dei primi 64 bit. |
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
|
|
|
|
|
|
#10 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Scusa la mia ignoranza, ma perche' i secondi vengono calcolati a partire dal 1 gennaio 1970?? In questo modo mi viene indicata l'ora e data corrente???
Comunque il problema rimane perche' non so come generare una rappresentazione a 64 bit della data e ora |
|
|
|
|
|
#11 |
|
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2780
|
E' una convenzione, il primo gennaio 1970 è la cosiddetta "Unix epoch". A partire da quanti secondi sono trascorsi da quella data puoi inferire data, ora, minuti e secondi. Quindi non ti serve altro.
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Tutti gli orologi di sistema dei PC partono dal 1 gennaio 1970.
Tu non devi ottenere la data e l'ora, ma il numero di secondi dal 1 gennaio 1970 sono già una rappresentazione di data e ora. |
|
|
|
|
|
#13 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Ok grazie per la lucidazione
Ci sara' quindi una funzione che mi restituirà un intero contenente i secondi trascorsi dal 1 gennaio 1970..giusto??quindi avro' una rappresentazione a 32 bit...e per espanderlo a 64??? Ultima modifica di ARGENTOVIVO81 : 02-12-2009 alle 21:27. |
|
|
|
|
|
#14 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Ho trovato la funzione time() della libreria time.h che restituisce un intero di 8 byte chiamato time_t.Quindi non mi rimane che calcolare il valore hash e concatenare l'output di time() e del valore hash in una nuova variabile di 128 bit. Cosi' dovrebbe funzinare..no??
|
|
|
|
|
|
#15 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Con quale sistema operativo stai facendo il programma ?
|
|
|
|
|
|
#16 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
Linux..sto utilizzando la slackware 12.2 (imposta dal mio prof) e ambiente di programmazione KDE.
Con la funzione time() risolvo questo primo problema della rappresentazione a 64 bit dell'ora e data ???
|
|
|
|
|
|
#17 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Utilizza gettimeofday. Ti rende sia il numero di secondi dall'1/1/1970 che il numero di microsecondi.
Non so la dimensione, credo comunque che siano 32 bit sia per i secondi che per i microsecondi. |
|
|
|
|
|
#18 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
scusa, ma in questo caso, a cosa mi servono i microsecondi dato che i secondi trascorsi dal 1/1/1970 forniscono gia' l'ora e data corrente??
|
|
|
|
|
|
#19 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
|
|
|
|
|
|
#20 |
|
Member
Iscritto dal: Dec 2009
Messaggi: 41
|
scusami ma non ho capito...potresti spiegarmelo meglio??
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 23:57.




















