Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > PHP
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
Imagenes en PHP con librería GD y datos de DB

Hola a tod@s, aprobecho mi primer mensaje para mandar un saludo

Bueno, mi problema es el siguiente:

Estoy intentando crear una imagen con contenido extraido de la Base de datos en MySQL.

Si introduzco los datos con el GET no hay problemas, pero al hacer SELECT de la DB me salen errores por todas partes, podriais echarme una mano?

Muchas gracias!
Responder Con Cita
  #2  
Antiguo 23-01-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Pues sin nada del código que usas ni el tipo de errores que te salen, está un poco difícil. Sólo puedo decirte, hazlo con cuidado y revisa bien todo.

// Saludos
Responder Con Cita
  #3  
Antiguo 23-01-2007
Avatar de droguerman
droguerman droguerman is offline
Miembro
 
Registrado: abr 2005
Ubicación: tierra
Posts: 999
Poder: 20
droguerman Va por buen camino
casi podria apostar que el problema es por el maxlength del input o por comillas
__________________
self.free;
Responder Con Cita
  #4  
Antiguo 23-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
Hola de nuevo, lo siento, pero es que no tenía el código a mano cuando escribí el post...

El código es el siguiente:
Código PHP:
<?php
include "connect.php";
header("Content-type: image/png");
$ide $_GET['id'];

$im    imagecreatefrompng("images/image.png");
$orange imagecolorallocate($im22021060);
$px    = (imagesx($im) - 7.5 strlen($ide)) / 2;

$query mysql_query("SELECT * FROM table WHERE id =".$ide);

while(
$row mysql_fetch_array($query)) {
    
$txt $row[nombre];
    }

imagestring($im3$px9$txt$orange);
imagepng($im);
imagedestroy($im);

?>
Dentro del while se cogerían más elementos de la tabla, pero aquí lo he puesto más simplificado.

Gracias de nuevo!

edito:
El error que me sale es:
No se puede mostrar la imagen "URL" porque contiene errores

en cambio el código con el GET si que funciona, y es este:
Código PHP:
<?php

header
("Content-type: image/png");
$string $_GET['text'];
$im    imagecreatefrompng("signtargs/image.png");
$orange imagecolorallocate($im22021060);
$px    = (imagesx($im) - 7.5 strlen($string)) / 2;
imagestring($im3$px9$string$orange);
imagepng($im);
imagedestroy($im);

?>

Última edición por GabberMan fecha: 23-01-2007 a las 22:40:33.
Responder Con Cita
  #5  
Antiguo 23-01-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Verifica el contenido de $txt, ¿qué es lo que realmente mandas a imagestr?

Te lo digo porque es posible que se esté metiendo "ruido". Hice una prueba similar a lo tuyo y primero no obtuve ningún error, pero me fijé que en tu ciclo while la variable $txt siempre se reasigna perdiéndose el valor anterior. Imagino que es una errata y en realidad estás concatenando al valor anterior:

Código PHP:
$txt .= $row[nombre]; 
Pero cuando hice esa modificación, la imagen salió en blanco. Entonces probé que pasaba con $txt haciendo un

Código PHP:
die($txt); 
y vi algo como esto:

Cita:
<br />
<b>Notice</b>: Undefined variable: txt in ....
antes del texto que quería. Y los carcateres especiales son los que meten ruido. Aquí el problema es que $txt no tenía un valor inicial.

Checa. Quizá por ahí esté el problema.

// Saludos
Responder Con Cita
  #6  
Antiguo 23-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
Bueno, técnicamente el bucle sólo debe hacer una vuelta, ya que únicamente hay una fila con el id dado. Y si, es una concatenación pero lo he borrado para que el código sea menos largo :P (luego lo he corregido)

El contenido es texto, concretatemente la cadena test, por lo que no se que puede haber de ruido...

¿die($txt); que hace exactamente?

Muchas gracias por tu ayuda, miraré si es por el contenido de $txt

Un Saludo!
Responder Con Cita
  #7  
Antiguo 23-01-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
die es nada más para parar la ejecución y mostrar el texto que le pases.

// Saludos
Responder Con Cita
  #8  
Antiguo 24-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
Nunca te acostarás sin saber una cosa más

Gracias por contestar

Un Saludo!
Responder Con Cita
  #9  
Antiguo 25-01-2007
[kayetano] kayetano is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Elche
Posts: 644
Poder: 22
kayetano Va por buen camino
Hola

Cita:
Empezado por GabberMan
Bueno, técnicamente el bucle sólo debe hacer una vuelta, ya que únicamente hay una fila con el id dado. Y si, es una concatenación pero lo he borrado para que el código sea menos largo :P (luego lo he corregido)
Pues entonces:
Código PHP:
<?
if( $row mysql_fetch_array($query)) {
    
$txt $row['nombre'];
} else {
// Acciones de error
}
?>
Dependiendo de la configuración de tu servidor apache podrás utilizar la sintaxis con comillas o sin comillas en los arrays, es decir $row['nombre'] o $row[nombre], yo siempre utilizo comillas.

Más cosas, te aconsejo que entrecomilles todas los valores en una sentencia SQL.
Código PHP:
<?
$query 
mysql_query("SELECT * FROM table WHERE id ='".$ide."'");
?>
Además no estaría mal que filtraras la variable "$ide" para evitar inyección de código HTML.

Por último, DIE() es un alias de EXIT() y simplemente finaliza el script en curso y como opcional puedes mostrar un mensaje.
Desconozco el porque al gente utilizar una alias antes que la función directa pero asin es la vida.
__________________
Salu2
KAYETANO

Cómo hacer preguntas de manera inteligente
Responder Con Cita
  #10  
Antiguo 25-01-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por kayetano
Desconozco el porque al gente utilizar una alias antes que la función directa pero asin es la vida.
Esteee...Pues en en mi caso porque cuando empecé a programar con php y aún ahora, consulto mucho el manual, en donde muchos ejemplos usan die() en lugar de exit()

// Saludos
Responder Con Cita
  #11  
Antiguo 26-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
Gracias por la ayuda kayetano, me ha ido muy bien el código que me aconsejaste, y ya tendré cuidado con el GET, que no había caido en eso.

He cambiado el código completamente, y ha quedado algo tal que así:
Código PHP:
<?php
Header
("Content-type: image/png"); 

include 
"connect.php";

$im    imagecreatefrompng("images/image.png");
$orange imagecolorallocate($im22021060);

$query mysql_query("SELECT * FROM table WHERE id=1");

if( 
$row mysql_fetch_array($query)) {
    
$txt $row['nombre'];
} else {
  
$txt "ERROR";


$px = (imagesx($im) - 7.5 strlen($txt)) / 2;
imagestring($im3$px9$txt$orange);
imagepng($im);
imagedestroy($im);

?>
Y ahora por lo menos me ha cambiado de error si sale una página llena de carácteres especiales...

Hice una prueba para ver que salía por pantalla al hacer el SELECT, y es una cadena de texto limpia... ¿Puede ser que incluir connect.php pete el script?

Ya no se que más hacer... gracias por la ayuda!

_edito: Pues resulta que si, cambiando el código por:

Código PHP:
<?php
header
("Content-type: image/png");

$username "user";
$password "pass";
$database "db";

mysql_connect('dir',$username,$password)or die(mysql_error());
@
mysql_select_db($database)or die('Failed to select database.');

$im    imagecreatefrompng("images/image.png");
$orange imagecolorallocate($im22021060);


$query mysql_query("SELECT * FROM tabla WHERE id = 1");

if( 
$row mysql_fetch_array($query)) {
    
$txt $row['nombre'];
} else {
  
$txt "ERROR";


$px    = (imagesx($im) - 7.5 strlen($txt)) / 2;

imagestring($im3$px9$txt$orange);
imagepng($im);
imagedestroy($im);

?>
No hay fallos y la imagen se ve correctamente.

Muchas gracias a todos!!

Última edición por GabberMan fecha: 26-01-2007 a las 00:41:54.
Responder Con Cita
  #12  
Antiguo 26-01-2007
[kayetano] kayetano is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Elche
Posts: 644
Poder: 22
kayetano Va por buen camino
Hola

Cita:
Empezado por GabberMan
_edito: Pues resulta que si, cambiando el código por:
No te equivoques, el tema del CONNECT no tiene nada que ver con que la imagen se te vea bien o mal, a mi me ha pasado lo que a ti muchas veces y simplemente es un error del navegador, supongo que se le va la (al navegador) pinza por tantas pruebas. Para asegurarte que tu script funciona simplemente debes hacer lo siguiente:
Código:
   <img src="mi_script.php?id=1">
Asi no recuerdo que me haya fallado nunca un script de visualización de imágenes, ya sea con GD o con IMAGEMAGICK.
__________________
Salu2
KAYETANO

Cómo hacer preguntas de manera inteligente
Responder Con Cita
  #13  
Antiguo 26-01-2007
GabberMan GabberMan is offline
Registrado
 
Registrado: ene 2007
Posts: 6
Poder: 0
GabberMan Va por buen camino
No se, probé en IE y FireFox y no funcionaba en ninguno de los 2 ni limpiando caché, y al cambiar el connect por el código me funciona sin problemas

En cuanto llegue a casa lo pruebo con el <img>.
Responder Con Cita
  #14  
Antiguo 26-01-2007
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
¿Estás seguro que el connect funciona? Es decir, que realmente logra conectarse sin marcar errores? Como dice kayetano, no tendría nada que ver.

Cita:
Empezado por kayetano
a mi me ha pasado lo que a ti muchas veces y simplemente es un error del navegador, supongo que se le va la (al navegador) pinza por tantas pruebas
A mi me pasa algo similar cuando genero pdfs, de pronto lo que aparece es el código del pdf y no el documento. Nunca he sabido bien a qué se debe.

// Saludos
Responder Con Cita
  #15  
Antiguo 27-01-2007
[kayetano] kayetano is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Elche
Posts: 644
Poder: 22
kayetano Va por buen camino
Hola

Cita:
Empezado por roman
A mi me pasa algo similar cuando genero pdfs, de pronto lo que aparece es el código del pdf y no el documento. Nunca he sabido bien a qué se debe.
Ahora que lo dices a mi también me ha pasado con los PDF.
__________________
Salu2
KAYETANO

Cómo hacer preguntas de manera inteligente
Responder Con Cita
  #16  
Antiguo 28-01-2007
Avatar de droguerman
droguerman droguerman is offline
Miembro
 
Registrado: abr 2005
Ubicación: tierra
Posts: 999
Poder: 20
droguerman Va por buen camino
creo que añadiendo addmimetype a la configuración de apache se puede corregir aunque no lo he probado
__________________
self.free;
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Tratamiento de base de datos con Imagenes zugazua2001 Gráficos 5 25-03-2012 21:12:31
Imagenes en base de datos Esau Gráficos 4 04-02-2007 21:14:43
imagenes en base de datos davidgaldo Varios 0 14-04-2005 16:22:36
Guardar imagenes en una base de datos PTW Varios 1 09-04-2004 14:50:16
FreeReport e imagenes en Base de datos rpadin Impresión 1 24-02-2004 22:13:50


La franja horaria es GMT +2. Ahora son las 19:15:41.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi