Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-05-2007, 14:15   #1
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
[JAVA] availability di un ObjectInpuStream

Mi succede una cosa veramente strana con un ObjectInputStream, ho un file contenente degli oggetti scritti con un writeObject() da un ObjectOutputStream e che cerco di rileggere con un ObjectInputStream, apro un FileInputStream sul File e lo inscatolo dentro l'ObjectInputStream, solo che l'availability di quest'ultimo è zero mentre quello del FileInputStream no!!!!
Questo è il codice
Codice:
FileInputStream fis=new FileInputStream(this.theFile);
            ObjectInputStream ois=new ObjectInputStream(fis);
            System.out.println("Starting the cycle, availability (ois):"+String.valueOf(ois.available())+", availability (fis):"+String.valueOf(fis.available()));
            while (ois.available()>0){
                System.out.println("I'm in, trying to read");
                ris.add((IEsame)ois.readObject());
                System.out.println("I'm in, read");
            }
            ois.close();
            fis.close();
            return ris;
e questo è l'output quando chiamo questo metodo
Codice:
Starting the cycle, availability (ois):0, availability (fis):5617
A questo punto non so cme mai il fis ha disponibilità di byte e uando (nella riga dopo) lo inscatolo in un ObjectInputStream sembra che perda il suo contenuto!!!! (Naturalmente nel ciclo non ci entra mai)
Qualcuno ha qualche idea????
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 14:53   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Non usare available(). E' un metodo che ha una documentazione sibillina. In particolare non si capisce se possa restituire zero, anche senza aver raggiunto la fine del file, quando non sia possibile leggere ulteriori byte senza bloccare il flusso di controllo. Probabilmente restituisce zero in entrambi i casi, cioè se ha raggiunto la fine del flusso oppure è possibile leggere zero byte prima di un blocco.

Usa FileChannel, position() e size() e vai sul sicuro.

Codice:
FileChannel channel = new FileInputStream(file).getChannel();
ObjectInputStream ois = new ObjectInputStream(Channels.newInputStream(channel));
while(channel.position() < channel.size()) {
     Object o = ois.readObject();
}
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!

Ultima modifica di PGI-Bis : 08-05-2007 alle 14:54. Motivo: Un po' di grammatica, via!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 15:17   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da morskott Guarda i messaggi
Mi succede una cosa veramente strana con un ObjectInputStream, ho un file contenente degli oggetti scritti con un writeObject() da un ObjectOutputStream e che cerco di rileggere con un ObjectInputStream, apro un FileInputStream sul File e lo inscatolo dentro l'ObjectInputStream, solo che l'availability di quest'ultimo è zero mentre quello del FileInputStream no!!!!
Se devi deserializzare diversi oggetti senza sapere quanti sono a priori, una possibile idea potrebbe essere quella di fare la lettura in un ciclo infinito e di catturare all'esterno del ciclo l'eccezione EOFException, in modo che quando viene lanciata, il ciclo di lettura termina.

Può sembrare un po' "rozzo" ma funziona. (PGI-Bis, sei d'accordo con me?).
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 15:21   #4
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
Adesso ho una exception veramente esotica
Codice:
java.io.StreamCorruptedException: invalid type code: AC
	at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1356)
	at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
	at esami2.dao.EsameDAO.findAll(EsameDAO.java:79)
	at esami2.dao.EsameDAOTest.testFindAll(EsameDAOTest.java:105)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at junit.framework.TestCase.runTest(TestCase.java:154)
	at junit.framework.TestCase.runBare(TestCase.java:127)
at junit.framework.TestResult$1.protect(TestResult.java:106)
	at junit.framework.TestResult.runProtected(TestResult.java:124)
	at junit.framework.TestResult.run(TestResult.java:109)
	at junit.framework.TestCase.run(TestCase.java:118)
	at junit.framework.TestSuite.runTest(TestSuite.java:208)
	at junit.framework.TestSuite.run(TestSuite.java:203)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.run(JUnitTestRunner.java:297)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.launch(JUnitTestRunner.java:672)
	at org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner.main(JUnitTestRunner.java:567)
esattamente alla readObject(). Nel file ho fatto lo store di 3 oggetti con questo codice
Codice:
FileOutputStream fos=new FileOutputStream(this.theFile,true);
            ObjectOutputStream oos=new ObjectOutputStream(fos);
            oos.writeObject(esame);
            oos.close();
            fos.close();
Qualcuno sa spiegarmela????

Ultima modifica di morskott : 08-05-2007 alle 15:23.
morskott è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 17:07   #5
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Io sono restio ad usare le eccezioni come condizioni di controllo, anche quando si tratta di EOFException che, se non ricordo male, sarebbe fatta apposta. Preferisco il canale che, con il suo bel cursore, è lì pronto a dirci quando non c'è più trippa per gatti.

morskott, devi mantenere una specularità tra il modo in cui scrivi ed il modo in cui leggi.

Se la serializzazione di più oggetti avviene aprendo e chiudendo l'ObjectOutputStream per ogni scrittura allora la lettura di più oggetti deve essere fatta aprendo un nuovo ObjectInputStream per ogni oggetto.

Se la serializzazione di più oggetti avviene "riciclando" uno stesso ObjectOutputStream (cioè lo apri una volta, ci scrivi 10 oggetti e poi lo chiudi) allora la deserializzazione va fatta riciclando uno stesso ObjectInputStream (lo apri una volta, leggi finchè puoi e poi lo chiudi).

Il tuo codice rientra nel primo caso.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 08-05-2007, 18:52   #6
morskott
Member
 
Iscritto dal: Jul 2005
Messaggi: 291
risolto!!!!!!
grazie PGI!!!
morskott è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Invia il tuo nome a 1,5 milioni di chilo...
Apple MacBook Neo 13'' con chip A18 Pro ...
Insieme a Leica SL3-P presentate le otti...
La Cina svilupperà anche il razzo...
Rocket Lab e la missione Victus Haze per...
Starship: Ship 40 ha eseguito uno static...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
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: 01:48.


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