Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   PHP (https://www.clubdelphi.com/foros/forumdisplay.php?f=15)
-   -   Imagenes en PHP con librería GD y datos de DB (https://www.clubdelphi.com/foros/showthread.php?t=39544)

GabberMan 23-01-2007 18:58:29

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!

roman 23-01-2007 20:12:49

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

droguerman 23-01-2007 21:17:40

casi podria apostar que el problema es por el maxlength del input o por comillas

GabberMan 23-01-2007 22:36:21

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);

?>


roman 23-01-2007 23:19:55

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

GabberMan 23-01-2007 23:37:23

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!

roman 23-01-2007 23:40:43

die es nada más para parar la ejecución y mostrar el texto que le pases.

// Saludos

GabberMan 24-01-2007 01:42:01

Nunca te acostarás sin saber una cosa más

Gracias por contestar

Un Saludo!

kayetano 25-01-2007 14:53:46

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.

roman 25-01-2007 17:59:58

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() :D

// Saludos

GabberMan 26-01-2007 00:19:25

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!!

kayetano 26-01-2007 09:00:34

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.

GabberMan 26-01-2007 12:17:16

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 :D

En cuanto llegue a casa lo pruebo con el <img>.

roman 26-01-2007 17:37:47

¿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

kayetano 27-01-2007 13:44:30

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.

droguerman 28-01-2007 18:38:24

creo que añadiendo addmimetype a la configuración de apache se puede corregir aunque no lo he probado


La franja horaria es GMT +2. Ahora son las 05:17:59.

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