Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
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


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
HONOR inaugura il primo ALPHA Flagship S...
Yamaha: ecco il brevetto del 'finto moto...
'Console obsoleta e utenti ingannati': u...
Stop al ransomware su Google Drive, graz...
L'IA è la nuova interfaccia utent...
Battlefield 6: confermata la dimensione ...
Windows 11 porta il Wi-Fi 7 alle aziende...
Logitech MX Master 4 subito disponibile ...
'Nonna Skyrim' dice addio all'RPG di Bet...
PlayStation 5 Slim a 399€ o bundle con N...
roborock Qrevo Curv S5X in offerta a 649...
Sapphire Nitro+ B850A WIFI 7: la nuova s...
CraftGPT: un giocatore costruisce ChatGP...
Il Conto Termico 3.0 è ufficiale:...
Tesla inaugura la stazione di ricarica S...
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: 16:09.


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