Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Dal richiamo di Enrico Letta alla necessità di completare il mercato unico entro il 2028 alla visione di Nokia sul ruolo dell’IA e delle reti intelligenti, il Nokia Innovation Day 2025 ha intrecciato geopolitica e tecnologia, mostrando a Vimercate come la ricerca italiana contribuisca alle sfide globali delle telecomunicazioni
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-05-2007, 12: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, 14: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, 14: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, 15: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, 15: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, 16: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, 08: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, 15: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


Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
SpaceX guarda ai primi voli orbitali del...
Il prototipo del razzo spaziale riutiliz...
Blue Origin mostra uno spettacolare vide...
Roscosmos: la capsula Bion-M2 è r...
ASUS sperimenta GPU senza connettori di ...
La Cina conquisterà lo spazio ent...
Samsung ha un nuovo entry level: debutta...
Caos nei cieli europei: attacco informat...
Volkswagen ferma la produzione di ID.Buz...
Super sconti del weekend Amazon: 5 novit...
Dreame non si ferma più: tra le n...
Samsung Galaxy Buds3 FE a meno di 95€ su...
Praticamente regalate: 135€ per le Squie...
Si rinnovano i coupon nascosti di settem...
Amazon sconta i componenti: occasioni d'...
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: 00:09.


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