Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
All'evento globale di Nutanix l'azienda ha presentato una serie di novità mirate a ridurre la dipendenza dalle soluzioni di VMware/Broadcom. Arriva Cloud Native AOS, soluzione che non richiede di appoggiarsi ad hypervisor. Novità per Nutanix Enterprise AI. Potenziata la collaborazione con Pure Storage per uno storage dedicato ad altissime prestazioni
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI è capace di sorprendere ancora e quest’anno lo fa con questo nuovo smartwatch WATCH FIT 4 Pro che coniuga un design elegante e moderno con funzionalità di prim’ordine. Ultra-sottile con display AMOLED, funzionalità avanzate per sport e salute, e un'autonomia fino a 10 giorni.
Test NIU RQi Sport, vi spieghiamo perché una moto così è perfetta
Test NIU RQi Sport, vi spieghiamo perché una moto così è perfetta
Abbiamo potuto provare la moto elettrica di NIU per diversi giorni, ed abbiamo capito davvero il senso di queste moto moderne e semplici da utilizzare
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-01-2010, 21:56   #1
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
[PHP + Mysql]prelevare e visualizzare un'immagine da un DB

Codice PHP:
$host='localhost';
    
$nome_database='prova';
    
$nome_utente='root';
    
$password='';
    
$connessione=mysql_connect($host,$nome_utente,$password);
    
mysql_select_db($nome_database);                                
    
$query "SELECT codice_immagine FROM immagine WHERE chiave= 1";
    
$risultato mysql_query($query) or die('Query non valida: ' mysql_error());
    
$tmp mysql_fetch_array($risultato);
    
header('Content-Type:  image/jpeg');
    echo 
$tmp['image']; 
salve a tutti, vi ho postato il codice con cui intendo prelevare una immagine dal database (di nome prova), la tabella si chiama (immagine) e il campo contenitore dell'immagine è (codice_immagine), ma alla fine, lo eseguo e scrive questo:
"http://localhost/prova%20immagini/mostraImg.php"
mostraImg.php è il nome del file che eseguo...

vi prego, non riesco a capire il perchè, su internet è tutto incasinato!!
grazie mille

__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2010, 22:00   #2
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
fai una SELECT chiedendo il campo codice_immagine e poi cerchi di stampare $tmp['image'] invece di $tmp['codice_immagine'] e quindi ti stampa, ovviamente, una stringa vuota. Cambiando la chiave dell'array dovrebbe funzionare
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 11:46   #3
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
"mysql_fetch_array" ritorna i campi indicizzati da numeri interi, quindi devi usare echo $tmp[0];
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 13:42   #4
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
vi ringrazio ragazzi...
ho provato a cambiare l'indice del vettore $temp
sia mettendo 0 che mettendo codice_immagine
ma non è successo nulla

__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 15:54   #5
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
Quote:
Originariamente inviato da flx2000 Guarda i messaggi
"mysql_fetch_array" ritorna i campi indicizzati da numeri interi, quindi devi usare echo $tmp[0];
veramente restituisce un array con i campi indicizzati SIA da interi che dai nomi delle colonne (almeno se non specifichi il secondo parametro).

Quote:
Originariamente inviato da cruyffissimo Guarda i messaggi
vi ringrazio ragazzi...
ho provato a cambiare l'indice del vettore $temp
sia mettendo 0 che mettendo codice_immagine
ma non è successo nulla

hai provato a farti stampare il numero di righe che ottieni dalla query? con mysql_num_rows()
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 16:26   #6
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Quote:
Originariamente inviato da Torav Guarda i messaggi
veramente restituisce un array con i campi indicizzati SIA da interi che dai nomi delle colonne (almeno se non specifichi il secondo parametro).
Esatto, avevo dato per scontata la caratteristica di mysql_fetch_assoc che al contrario restituisce solo l'associativo.
Ad ogni modo avrebbe dovuto funzionare in entrambi i casi, quindi il problema è altrove.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 16:59   #7
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
sisi, risulta 1 come deve essere, ma proprio non capisco perchè mi stampa l'indirizzo in locale del file in php...
__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 17-01-2010, 18:48   #8
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Sei sicuro che non ci siano errori nella richiesta che fai?
Perché in caso di errori l'header è compromesso e non puoi più inviarlo col comando "header".

Prova a fare la query a mano con phpMyAdmin o un client mysql, e poi assicurati che la riga dell'header sia esattamente questa (maiuscole/minuscole/spazi esatti):
header("Content-type: image/jpeg");
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2010, 13:03   #9
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
ho provato e riprovato, la query è giusta...
ti posto ancora il codice..

Codice PHP:
$host='localhost';
    
$nome_database='prova';
    
$nome_utente='root';
    
$password='';
    
$connessione=mysql_connect($host,$nome_utente,$password);
    
mysql_select_db($nome_database);                                
    
$query "SELECT codice_immagine FROM immagine WHERE chiave= '1'";
    
$risultato mysql_query($query);
    
$tmp mysql_fetch_array($risultato);
    
header("Content-type: image/jpeg");
      echo 
$tmp['codice_immagine']; 
__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2010, 13:26   #10
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Non hai alcun log del programma?

Comunque ti consiglio di usare sempre le versioni "sicure", ad esmpio cambia mysql_select_db($nome_database); in mysql_select_db($nome_database,$connessione); e mysql_query($query); in mysql_query($query,$connessione);

Per il resto qualche punto di controllo non farebbe male:
$connessione = mysql_connect($host,$nome_utente,$password);
if ( $connessione == false ) { echo "Impossibile connettersi al db"; }

e cose del genere...
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2010, 17:15   #11
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
tutti i controlli li avevo evitati apposta,davo per scontato che funzionasse...cosa intendi per log, scusa la domanda...XD
__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2010, 21:10   #12
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
I log sono i file di diagnostica prodotti dai servizi per rendicontare ogni cosa che accade, dagli errori all'utilizzo ecc.
Ad ogni modo puoi forzare il PHP a gestire gli errori in un certo modo, inserendo all'inizio del tuo programma queste righe:

ini_set("display_errors",1);
error_reporting(E_STRICT); (usa E_ALL se non hai PHP 5)
ini_set("error_log","errori.txt");

In questo modo ad ogni esecuzione del tuo script potrai trovare in errori.txt tutto quello che è successo, di buono e/o di imprevisto.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 21-01-2010, 16:03   #13
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
ho provato...

cmq sembra tutto giusto...segnalo una cosa...tolgo l'header e mi stampa a video una serie di caratteri chiaramenti sarà la codifica in ascii dell'immagine in questione...il database è pieno, il campo è un campo blob...
magari è l'header che da problemi...

cosa ne pensi?

__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 21-01-2010, 16:14   #14
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Prova a fare questa cosa.
Al posto di:
header("Content-type: image/jpeg");
echo $tmp['codice_immagine'];
scrivi:
file_put_contents("prova.jpg",$tmp['codice_immagine']);

Scarica quel file prova.jpg così creato e vedi se è un'immagine valida.
Se non lo è la colpa non sta nel tuo codice PHP ma da qualche altra parte.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 21-01-2010, 18:00   #15
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
nulla...ma si può???che rabbia, ho provato anche a cancellare tutto il database e a farne uno prova, ma nulla...

tu come fai a scaricare le immagini dal database?
oppure, conosci un'altro metodo per scaricarle?


__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 09:19   #16
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
In genere non si mettono mai immagini nei database.
Molto più comodo inserire solo il link all'immagine, che poi vai a pescare in una cartella del webserver.

In pratica:
Codice:
header("Content-type: image/jpeg");
$db = mysql_connection(...bla,bla,bla...);
$res = mysql_query("select nome_file from immagine where chiave= '1'",$db);
$row = mysql_fetch_assoc($res);
readfile($row['nome_file']);
mysql_close($db);
flx2000 è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 11:21   #17
cruyffissimo
Member
 
L'Avatar di cruyffissimo
 
Iscritto dal: Oct 2009
Messaggi: 67
a ok capisco, però non si dipende troppo dalla posizione della foto nelle varie cartelle?
__________________
- Sei... Il numero perfetto!
- Ma non era Tre il numero perfetto?
- Si, ma la mia pistola ha sei colpi...

[cit:Il Buono...ne "Il Buono, Il Brutto E Il Cattivo"]
cruyffissimo è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 13:20   #18
vizzz
Senior Member
 
L'Avatar di vizzz
 
Iscritto dal: Mar 2006
Città: Bergamo
Messaggi: 2499
Quote:
Originariamente inviato da cruyffissimo Guarda i messaggi
a ok capisco, però non si dipende troppo dalla posizione della foto nelle varie cartelle?
ma l'immagine in che tipo di campo è?
__________________
ho concluso con: kvegeta, doctordb, Leland Gaunt.
vizzz è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 13:51   #19
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da cruyffissimo Guarda i messaggi
a ok capisco, però non si dipende troppo dalla posizione della foto nelle varie cartelle?
In che senso?

Tu basta che memorizzi in un campo ad hoc il nome dell'immagine poi il path assoluto e relativo dellastessa lo memorizzi in una variabile/costante di configurazione.

A meno di vincoli imprescindibili è sempre meglio usare il filesystem per memorizzare i file.
  Rispondi citando il messaggio o parte di esso
Old 22-01-2010, 16:08   #20
flx2000
Bannato
 
L'Avatar di flx2000
 
Iscritto dal: Nov 2002
Città: Roma
Messaggi: 810
Quote:
Originariamente inviato da Sgurbat Guarda i messaggi
[...]
A meno di vincoli imprescindibili è sempre meglio usare il filesystem per memorizzare i file.
Appunto.
E' notoriamente meglio evitare i bytecode direttamente dentro i database.
flx2000 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom Nutanix .NEXT: così l'azienda vuole aiuta...
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo! HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha...
Test NIU RQi Sport, vi spieghiamo perché una moto così è perfetta Test NIU RQi Sport, vi spieghiamo perché ...
Start Campus: il datacenter raffreddato dal mare Start Campus: il datacenter raffreddato dal mare
Samsung Galaxy S25 Edge: il 'sottile' capolavoro che sfida le leggi della fisica Samsung Galaxy S25 Edge: il 'sottile' capolavoro...
L'architettura Zen 6 si avvicina, AMD av...
Windows 10, richieste di ripristino BitL...
La nuova wallbox di SolarEdge decide qua...
Akamai punta sull’IA: alla scoperta dell...
Sony WH-1000XM6 e WH-1000XM4 a confronto...
Apple AirPods Pro 2 con USB-C a 199 euro...
TikTok obbliga gli adolescenti a meditar...
Recensione HUAWEI WATCH 5: la nobile art...
Super portatile HP da 1,38Kg, 14" 2...
Microsoft licenzia migliaia di programma...
400 nit per il nuovo prototipo Samsung E...
Che prezzi su Amazon: oggi iPhone 15 a 6...
Samsung One UI 8: ecco la roadmap e i di...
FRITZ!Box 7690 in offerta su Amazon: Wi-...
ChatGPT sperimenta MCP e Record per espa...
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: 09:35.


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