Foros del Web » Programando para Internet » PHP »

Ayuda con contador

Estas en el tema de Ayuda con contador en el foro de PHP en Foros del Web. He comprado una web semiterminada pero que tiene algunos problemas. En este caso hablo de contadores de descarga. Esta web suma una descarga cada vez ...
  #1 (permalink)  
Antiguo 03/10/2007, 04:54
 
Fecha de Ingreso: octubre-2007
Mensajes: 3
Antigüedad: 16 años, 7 meses
Puntos: 0
Ayuda con contador

He comprado una web semiterminada pero que tiene algunos problemas.

En este caso hablo de contadores de descarga. Esta web suma una descarga cada vez que se carga un archivo llamado ficha que es donde esta la descarga en lugar de sumar uno cuando se hace clic a la descarga (a su url).

Dejo parte del código donde creo que esta el error:

Código:
<? 

$des=mysql_fetch_array(mysql_query("select * from contenido where id='$_GET[id]'")); 

echo "<title>- Descarga Gratis - $des[titulo] -</title>\n"; 
?><? 

if (!$_GET[id]) { echo "<br>Error, debes especificar una ID. <a href=\"index.php\">Volver al index</a>."; } 
else { 
$des=mysql_fetch_array(mysql_query("select * from contenido where id='$_GET[id]'")); 
if (!$des) { echo "<br>Error, no existe la descarga"; } 
else { 
$poster=mysql_fetch_array(mysql_query("select id, user from usuarios where id='$des[id]'")); 
mysql_query("update contenido set descargas=descargas+1 where id='$_GET[id]'"); 

$level = $des[descargas] ; 
switch (1) { 
case $level >= 50 : 
$star = 'rate10.gif'; 
break; 
case $level >= 40 : 
$star = 'rate7.gif'; 
break; 
case $level >= 30 : 
$star = 'rate6.gif'; 
break; 
case $level >= 20 : 
$star = 'rate5.gif'; 
break; 
case $level >= 10 : 
$star = 'rate3.gif'; 
break; 
case $level < 9 : 
$star = 'rate1.gif'; 
break; 
default: 
$star = 'rate'.(floor($level/50) - 1).'.gif'; 
} 
$star = 'images/'.$star; 



?>
Con este script me suma 1 a las descargas pero siempre que se carga el script, yo quiero que sea cada vez que se hace clic a un enlace que esta en la base de datos como url igual que id es el número de la descarga.

A ver si se os ocurre algo que estoy desesperado.

Gracias
  #2 (permalink)  
Antiguo 03/10/2007, 06:27
Avatar de Kelpie  
Fecha de Ingreso: febrero-2002
Ubicación: NorthSpain
Mensajes: 609
Antigüedad: 22 años, 2 meses
Puntos: 8
Re: Ayuda con contador

Para conseguir eso debes actuar sobre ese enlace, pero no has puesto el aspecto que tiene...

1.- Si es del tipo directo al archivo:
Código HTML:
<a href='archivo.exe'>Descargar</a> 
Yo me plantearía crear un script nuevo similar al que has puesto arriba, pero que envíe el archivo en caso correcto. Suponiendo que le llames descargar.php, cambiar el enlace a
Código HTML:
<a href='descargar.php?id=idArchivo>Descargar</a> 
Y descargar.php sería algo así:


Código PHP:
<? 
  
if (!$_GET[id]) { 
  echo 
"<br>Error, debes especificar una ID. <a href=\"index.php\">Volver al index</a>."; } 
  else { 
   
$des=mysql_fetch_array(mysql_query("select * from contenido where id='$_GET[id]'")); 
   if (!
$des) { 
     echo 
"<br>Error, no existe la descarga"; } 
   else { 
     
mysql_query("update contenido set descargas=descargas+1 where id='$_GET[id]'"); 
     
header("Location=$des['url']); //<-- Aquí envíamos el archivo a descargar
    }
   }
?>
Y quitar del tuyo la línea que aumenta las descargas:

Código PHP:
//mysql_query("update contenido set descargas=descargas+1 where id='$_GET[id]'");  <--Esta línea sobraría en el original 
__________________
Kelpie
  #3 (permalink)  
Antiguo 03/10/2007, 16:21
 
Fecha de Ingreso: octubre-2007
Mensajes: 3
Antigüedad: 16 años, 7 meses
Puntos: 0
Re: Ayuda con contador

Kelpie eres un genio por la idea pero mis conocimientos de php son casi 0 y hago funcionar las cosas por el sistema prueba error hasta que sale.

Mira te pongo casi el codigo entero de lo que es el archivo php que tengo. Con este código cada vez que se carga el archivo (se llama ficha.php) se me suma 1 al numero de descargas de la ficha del archivo que sea (cada archivo de descarga de la web ejecuta su propia ficha).

Yo quiero que sume 1 descarga cuando realmente se descargue o por lo menos cuando se haga clic sobre el enlace que es
Código:
<? echo $des[laurl]; ?>
... a mi entender (ya digo que ni papa)

No sé si me he explicado porque entre mis nulos conocimientos y mis explicaciones enrevedas quien lo saque es el amo!!!

Dejo el codigo!
Código:
<?

		  $des=mysql_fetch_array(mysql_query("select * from contenido  where id='$_GET[id]'"));

                     echo "<title>- Descarga Gratis - $des[titulo] - </title>\n";
		  ?><?
     
                if (!$_GET[id]) { echo "<br>Error, debes especificar una ID. <a href=\"index.php\">Volver al index</a>."; }
                else {
                  $des=mysql_fetch_array(mysql_query("select * from contenido where id='$_GET[id]'"));
                  if (!$des) { echo "<br>Error, no existe la descarga"; }
                  else {
                    $poster=mysql_fetch_array(mysql_query("select id, user from usuarios where id='$des[id]'"));
                    mysql_query("update contenido set descargas=descargas+1 where id='$_GET[id]'");
               
										$level =   $des[descargas] ;
switch (1) {
    case $level >= 50 :
        $star = 'rate10.gif';
        break;
	case $level >= 40 :
        $star = 'rate7.gif';
        break;
	case $level >= 30 :
        $star = 'rate6.gif';
        break;
	case $level >= 20 :
        $star = 'rate5.gif';
        break;
	case $level >= 10 :
        $star = 'rate3.gif';
        break;
    case $level < 9 :
        $star = 'rate1.gif';
        break;
    default:
        $star = 'rate'.(floor($level/50) - 1).'.gif';
}
$star = 'images/'.$star;


                   
            ?>
<a href="<? echo $des[laurl]; ?>">Descargar</a>
              <?   }
             }

            ?>
Un millón de gracias!
  #4 (permalink)  
Antiguo 04/10/2007, 17:00
 
Fecha de Ingreso: octubre-2007
Mensajes: 3
Antigüedad: 16 años, 7 meses
Puntos: 0
Re: Ayuda con contador

Alguna otra sugerencia??

Please!
  #5 (permalink)  
Antiguo 04/10/2007, 17:08
Avatar de andruqui  
Fecha de Ingreso: agosto-2007
Mensajes: 269
Antigüedad: 16 años, 8 meses
Puntos: 2
Re: Ayuda con contador

Cita:
Iniciado por Kelpie Ver Mensaje
Código PHP:
<? 
  
if (!$_GET[id]) { 
  echo 
"<br>Error, debes especificar una ID. <a href=\"index.php\">Volver al index</a>."; } 
  else { 
   
$des=mysql_fetch_array(mysql_query("select * from contenido where id='$_GET[id]'")); 
   if (!
$des) { 
     echo 
"<br>Error, no existe la descarga"; } 
   else { 
     
mysql_query("update contenido set descargas=descargas+1 where id='$_GET[id]'"); 
     
header("Location=$des['url']); //<-- Aquí envíamos el archivo a descargar
    }
   }
?>

Yo le agregaria algun control al $_GET[id], seria sano para la seguridad de tus datos.

Saludos
Andres
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 17:19.