Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
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
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


Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
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...
Rocket Lab acquisisce Iridium: nasce un ...
Una ventola nascosta e un design fuori d...
Display e fotocamera insieme: a Zurigo n...
Lenovo Idea Tab Plus, il tablet per stud...
Un ingegnere di AMD ha riprodotto in cas...
SanDisk Optimus cresce con nuovi SSD cer...
Loongson contro Intel e AMD: dalla Cina ...
Australia, quasi tutti gli under-16 aggi...
Oltre 1.300 miliardi di dollari per la p...
Un nuovo studio mette in dubbio la natur...
Crisi Volkswagen, torna l'ipotesi cessio...
Il CERN spegne il Large Hadron Collider:...
Stranger Than Heaven avrà una storia mol...
Il futuro prezzo di PS6 preoccupa i gioc...
AMD Ryzen 10000 sempre più vicini...
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: 23:42.


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