Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-05-2007, 13:48   #1
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
[JAVA]Estrarre i meta tag da un BLOB

Ciao

Ho realizzato un'applicazione che si interfaccia ad un DB.
Per ora nei BLOB sono memorizzati soltanto file .jpg quindi non ho alcun problema, ma in teoria potrebbe esserci qualsiasi cosa...

Mi hanno detto che esistono modi per leggere i meta tag dal flusso di byte memorizzato nel BLOB, dal quale è possibile risalire al formato originale del file.

Quindi, se nel blob c'è una jpg mi posso comportare in un modo, se c'è un pdf in un altro... e così via.

Sapete dirmi qualche cosa a riguardo?

Grazie
Edde è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2007, 15:12   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Edde Guarda i messaggi
Ho realizzato un'applicazione che si interfaccia ad un DB.
Per ora nei BLOB sono memorizzati soltanto file .jpg quindi non ho alcun problema, ma in teoria potrebbe esserci qualsiasi cosa...

Mi hanno detto che esistono modi per leggere i meta tag dal flusso di byte memorizzato nel BLOB, dal quale è possibile risalire al formato originale del file.

Quindi, se nel blob c'è una jpg mi posso comportare in un modo, se c'è un pdf in un altro... e così via.

Sapete dirmi qualche cosa a riguardo?
Quando si effettua una query, si possono ottenere i meta-dati relativi alle colonne contenute nel result-set. Vedi la interfaccia java.sql.ResultSetMetaData.

Ma queste informazioni non hanno nulla a che fare con quello che c'è realmente nei campi! Sono solo informazioni sulle colonne, es. che nome hanno, che tipo sono (INT? CHAR? BLOB?), se sono auto-increment e così via.

Quindi se devi stabilire cosa c'è realmente in un campo BLOB hai giusto alcune possibilità:
- Esaminare il contenuto del BLOB per determinare il tipo di file (es. un PDF inizia con i caratteri %PDF-1.N).
- Memorizzare in un altro campo una informazione che permetta di determinare successivamente il tipo di file.

I meta-dati non centrano nulla, sono solo informazioni sulle colonne.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2007, 15:34   #3
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
Quote:
Originariamente inviato da andbin Guarda i messaggi
Quando si effettua una query, si possono ottenere i meta-dati relativi alle colonne contenute nel result-set. Vedi la interfaccia java.sql.ResultSetMetaData.

Ma queste informazioni non hanno nulla a che fare con quello che c'è realmente nei campi! Sono solo informazioni sulle colonne, es. che nome hanno, che tipo sono (INT? CHAR? BLOB?), se sono auto-increment e così via.

Quindi se devi stabilire cosa c'è realmente in un campo BLOB hai giusto alcune possibilità:
- Esaminare il contenuto del BLOB per determinare il tipo di file (es. un PDF inizia con i caratteri %PDF-1.N).
- Memorizzare in un altro campo una informazione che permetta di determinare successivamente il tipo di file.

I meta-dati non centrano nulla, sono solo informazioni sulle colonne.
Lui mi parlava di meta tag, per il resto non so...

L'interfaccia ResultSetMetaData la conosco e la uso, ad esempio proprio per stabilire se il campo in questione è proprio un BLOB (gli altri, per come funziona la mia applicazione, posso trattarli tutti come stringhe).

Il problema è che il DB non è mio, non lo conosco a priori, nè tantomeno posso aggiungere campi a tabelle già esistenti. L'idea è quella di un'applicazione che, dandogli in pasto un qualsiasi DB Oracle o MySQL, possa interfacciarsi e permetterne una navigazione "intelligente".

Detto questo, l'unica strada effettivamente percorribile, è quella che porta alla lettura delle informazioni che mi servono e che sono presenti all'interno dei byte del BLOB. A quanto ne so ogni file, a livello di byte, contiene una serie di informazioni nella sua parte iniziale (i meta tag di cui mi parlavano...). Tra queste informazioni c'è anche quella relativa al formato del file. Ecco, io devo trovare un modo per risalire a questa informazione specifica...

Sai come fare?
Edde è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2007, 16:03   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Edde Guarda i messaggi
Lui mi parlava di meta tag, per il resto non so...
Io pensavo (speravo ...) che parlassi di meta-dati, visto che i meta-tag sono i tag <meta> che si usano nelle pagine web ..... quindi non vedo cosa possa centrare.

Quote:
Originariamente inviato da Edde Guarda i messaggi
L'interfaccia ResultSetMetaData la conosco e la uso, ad esempio proprio per stabilire se il campo in questione è proprio un BLOB (gli altri, per come funziona la mia applicazione, posso trattarli tutti come stringhe).

Il problema è che il DB non è mio, non lo conosco a priori, nè tantomeno posso aggiungere campi a tabelle già esistenti. L'idea è quella di un'applicazione che, dandogli in pasto un qualsiasi DB Oracle o MySQL, possa interfacciarsi e permetterne una navigazione "intelligente".
Cosa poi si possa intendere per "navigazione intelligente" è tutto da stabilire .....

Quote:
Originariamente inviato da Edde Guarda i messaggi
Detto questo, l'unica strada effettivamente percorribile, è quella che porta alla lettura delle informazioni che mi servono e che sono presenti all'interno dei byte del BLOB. A quanto ne so ogni file, a livello di byte, contiene una serie di informazioni nella sua parte iniziale (i meta tag di cui mi parlavano...).
A ridaje .... questi non sono meta-tag .... semmai bisogna dire che molti formati di file sono strutturati in modo da avere all'inizio uno (o più) header di informazione. C'è da precisare che un riconoscimento del tipo di file basandosi solo sul contenuto può essere più o meno facile a seconda del formato di file. Una immagine GIF inizia con i byte che formano la parola GIF87a oppure GIF89a, una immagine BMP inizia con i caratteri BM. Altri sono più complessi ed è necessario verificare più byte anche in diversi punti del file.

Quote:
Originariamente inviato da Edde Guarda i messaggi
Tra queste informazioni c'è anche quella relativa al formato del file. Ecco, io devo trovare un modo per risalire a questa informazione specifica...
Stabilisci quali sono i formati che vuoi gestire, documentati sul loro formato e quindi scrivi del codice che testa i byte necessari.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2007, 16:28   #5
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
Quote:
Originariamente inviato da andbin Guarda i messaggi
Io pensavo (speravo ...) che parlassi di meta-dati, visto che i meta-tag sono i tag <meta> che si usano nelle pagine web ..... quindi non vedo cosa possa centrare.
Si sarà confuso coi nomi. E' un tipo molto competente

Quote:
Cosa poi si possa intendere per "navigazione intelligente" è tutto da stabilire .....
Ho usato le virgolette apposta
Cmq posso assicurarti che sta venendo un prodotto interessante

Quote:
A ridaje .... questi non sono meta-tag .... semmai bisogna dire che molti formati di file sono strutturati in modo da avere all'inizio uno (o più) header di informazione. C'è da precisare che un riconoscimento del tipo di file basandosi solo sul contenuto può essere più o meno facile a seconda del formato di file. Una immagine GIF inizia con i byte che formano la parola GIF87a oppure GIF89a, una immagine BMP inizia con i caratteri BM. Altri sono più complessi ed è necessario verificare più byte anche in diversi punti del file.

Stabilisci quali sono i formati che vuoi gestire, documentati sul loro formato e quindi scrivi del codice che testa i byte necessari.
Ahi, speravo di trovare qualche libreria già pronta, che lo facesse al posto mio... ho l'impressione che non sia esattamente un lavoruccio da due soldi...

Continuo a cercare, nel frattempo... grazie
Edde è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2007, 17:20   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Edde Guarda i messaggi
Ahi, speravo di trovare qualche libreria già pronta, che lo facesse al posto mio... ho l'impressione che non sia esattamente un lavoruccio da due soldi...
Qualcosa di già pronto potrebbe anche esistere, dovresti fare una ricerca perché non ne ho idea.

Se si vuole farlo da sé, non è nemmeno molto difficile. Ecco un esempio:
Codice:
import java.io.*;

public class FileType
{
    public enum ID { UNKNOWN, BMP, GIF, PNG }

    private static byte[] BMP = { 0x42, 0x4D };
    private static byte[] GIF_1 = { 0x47, 0x49, 0x46, 0x38, 0x37, 0x61 };
    private static byte[] GIF_2 = { 0x47, 0x49, 0x46, 0x38, 0x39, 0x61 };
    private static byte[] PNG = { (byte) 0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A };

    private FileType () { }

    public static ID detect (InputStream is)
        throws IOException
    {
        byte[] data = new byte[128];

        int len = is.read (data);

        if (match (data, len, 0, GIF_1) || match (data, len, 0, GIF_2))
            return ID.GIF;
        else if (match (data, len, 0, PNG))
            return ID.PNG;
        else if (match (data, len, 0, BMP))
            return ID.BMP;
        else
            return ID.UNKNOWN;
    }

    private static boolean match (byte[] data, int len, int start, byte[] search)
    {
        if (start + search.length > len)
            return false;

        for (int i = 0; i < search.length; start++, i++)
        {
            if (data[start] != search[i])
                return false;
        }

        return true;
    }
}
Per il momento ho messo il test solo per BMP/GIF/PNG ma si può estendere. Basta avere un InputStream (quindi va bene sia per un file che per un campo BLOB ) e fare:

FileType.ID id = FileType.detect (is);

Nulla di trascendentale, come vedi.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2007, 09:29   #7
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
Ero sicuro di averti risposto ieri sera, ma a quanto pare mi sono sbagliato

Grazie dello spunto... in effetti è meno complicato di quello che pensavo.
Cmq forse ho trovato delle librerie che fanno al caso mio (era effettivamente impossibile che nessuno ci avesse mai pensato)...

Vi aggiornerò sui progressi
Edde è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2007, 16:28   #8
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
Fatto

http://schmidt.devlib.org/ffident/index.html

Roba un po' vecchiotta ed abbandonata da tempo, ma si tratta di 3 classi ed un piccolo file con l'elenco delle info sui fari formati (buggato, tra le altre cose... mi ha fatto perdere un sacco di tempo).

Cmq un bel prodotto, tra l'altro molto espandibile, visto che basta aggiungere delle righe a quel file per permettere il riconoscimento di altri formati...
Edde è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Sembra ormai certo: la prossima Xbox sar...
“Solutions Beyond Displays”: la strategi...
La società europea The Exploratio...
Dalle auto ai robot umanoidi: Faraday Fu...
Vodafone annuncia la dismissione di un s...
Stiga lancia i nuovi robot tagliaerba co...
Bullismo e cyberbullismo, Keenetic lanci...
Con AI Skills Checker Bitdefender mette ...
E-bike giapponese con 1.000 km di autono...
Un eVTOL con cui basta saper andare in b...
Dal mercato cinese al mondo: HONOR firma...
Sovranità digitale: l'UE sperimen...
Accesso alla memoria su Windows 11 solo ...
iPhone 18 Pro Max con batteria da oltre ...
Windows 11, cali di prestazioni sulle GP...
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: 06:26.


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