Foros del Web » Programando para Internet » PHP »

variables por get en links

Estas en el tema de variables por get en links en el foro de PHP en Foros del Web. en la barra izquierda despliega las categorias con variables por metodo get en los links, en el centro despliega la lista de noticias por la ...
  #1 (permalink)  
Antiguo 10/04/2013, 02:49
Avatar de CMushroom  
Fecha de Ingreso: diciembre-2011
Ubicación: Morelos
Mensajes: 99
Antigüedad: 12 años, 10 meses
Puntos: 1
Pregunta variables por get en links

en la barra izquierda despliega las categorias con variables por metodo get en los links, en el centro despliega la lista de noticias por la categoria que des clic de 'ListaCategoria.php pero una vez ahi (supongamos que di clic al link videojuegos y me depliega correctamete por medio del script ListaNoticia.php, pero una vez ahi decido dar clic en categoria musica y se juntan las variables por get del llink anterior y el recien cliqueado, o no se que pasa que me carga los articulos de ambas categorias videojuegos y musica en vez de cargar solo articulos de musica como puedo corregirlo

Index.php

Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Documento sin título</title>
</head>

<body">
<div style="float:left; width: 23%;">
<?php include('ListaCategoria.php'); ?>
<?php 
include('Administrador.php'); ?>
</div>

<div style="float:left; width: 54%;">
<?php include('ListaNoticia.php'); ?>
</div>

<div style="float:right; width: 23%;">
<?php include('imagenes.php'); ?>
</div>

</body>
</html>
ListaCategoria.php

Código PHP:
<h1>Categorias</h1>
<?php
include ('Conexion.php');
$consulta mysql_query("SELECT * FROM categorias"$LinkBaseDatos) or die(mysql_error);
include (
'CerrarConexion.php');

echo 
"<ul>";
echo 
"<li><a href='index.php'>Todas</a>";

while(
$fila mysql_fetch_array($consulta))
    {
    echo 
"<li><a href='index.php?categoria=$fila[Categorias]&amp;id=$fila[CategoriasID]'>$fila[Categorias]</a></li>";
    }
echo 
"</ul>";
?>
ListaNoticia.php

Código PHP:
<?php 
$clausula 
"";
if(isset(
$_GET['id']) && isset($_GET['categoria']))
    {
    
$categoriaID $_GET['id'];
    
$categoria $_GET['categoria'];
    
$clausula "WHERE CategoriaID = '$categoriaID'";
    
    
$titulo "Noticias en la categoria $categoria";
    }
else
    {
    
$titulo "Todas las noticias";
    }
    
include (
'Conexion.php');    
$Select mysql_query("SELECT * FROM noticias $clausula"$LinkBaseDatos) or die(mysql_error);
include (
'CerrarConexion.php');

echo 
"<h2>$titulo</h2>";
while(
$filaNoticia mysql_fetch_array($Select))
    {
    
$CadenaRecortada substr($filaNoticia['Texto'],0,300); 
        
    echo 
"<a href='articulo.php?ID=$filaNoticia[NoticiasID]&amp;Titulo=$filaNoticia[Titulo]&amp;Video=$filaNoticia[Video]&amp;Texto=$filaNoticia[Texto]&amp;Foto=$filaNoticia[Foto]&amp;CategoriaID=$filaNoticia[CategoriaID]&amp;'><h3>$filaNoticia[Titulo]</h3></a>";
    
    echo 
$filaNoticia['Subtitulo']." ".$filaNoticia['Fecha']."<br><br>";
    echo 
"<img src='$filaNoticia[Foto]' height='200'><br><br>";
    echo 
$CadenaRecortada."<a href='articulo.php?ID=$filaNoticia[NoticiasID]&amp;Titulo=$filaNoticia[Titulo]&amp;Video=$filaNoticia[Video]&amp;Texto=$filaNoticia[Texto]&amp;Foto=$filaNoticia[Foto]&amp;CategoriaID=$filaNoticia[CategoriaID]&amp;'>...Seguir leyendo</a>";  
    }    
?>
  #2 (permalink)  
Antiguo 10/04/2013, 03:02
Avatar de hades87  
Fecha de Ingreso: diciembre-2007
Ubicación: Barcelona - España
Mensajes: 3.194
Antigüedad: 16 años, 11 meses
Puntos: 68
Respuesta: variables por get en links

Podrías mostrar además como te queda la URL cuando te muestra las dos categorías?=
__________________
No diseñes usando tablas.
  #3 (permalink)  
Antiguo 10/04/2013, 03:17
Avatar de CMushroom  
Fecha de Ingreso: diciembre-2011
Ubicación: Morelos
Mensajes: 99
Antigüedad: 12 años, 10 meses
Puntos: 1
Respuesta: variables por get en links

Cita:
Iniciado por hades87 Ver Mensaje
Podrías mostrar además como te queda la URL cuando te muestra las dos categorías?=
listanoticias.php la cambie en el link y ya funciona cuando cambio de categorias solo carga los respectivos articulos de cada una, ahora el problema es cuando doy clic en el link de el articulo que escoja de la lista pues carga todos los articulos de todas categorias.

Código PHP:
<?php 
$clausula 
"";
if(isset(
$_GET['id']) && isset($_GET['categoria']))
    {
    
$categoriaID $_GET['id'];
    
$categoria $_GET['categoria'];
    
$clausula "WHERE CategoriaID = '$categoriaID'";
    
    
$titulo "Noticias en la categoria $categoria";
    }
else
    {
    
$titulo "Todas las noticias";
    }
    
include (
'Conexion.php');    
$Select mysql_query("SELECT * FROM noticias $clausula"$LinkBaseDatos) or die(mysql_error);
include (
'CerrarConexion.php');

echo 
"<h2>$titulo</h2>";
while(
$filaNoticia mysql_fetch_array($Select))
    {
    
$CadenaRecortada substr($filaNoticia['Texto'],0,300); 
        
    echo 
"<a href='articulo.php?ID=$filaNoticia[NoticiasID]&amp;Titulo=$filaNoticia[Titulo]&amp;Video=$filaNoticia[Video]&amp;Texto=$filaNoticia[Texto]&amp;Foto=$filaNoticia[Foto]&amp;CategoriaID=$filaNoticia[CategoriaID]&amp;'><h3>$filaNoticia[Titulo]</h3></a>";
    
    echo 
$filaNoticia['Subtitulo']." ".$filaNoticia['Fecha']."<br><br>";
    echo 
"<img src='$filaNoticia[Foto]' height='200'><br><br>";
    echo 
$CadenaRecortada."<a href='articulo.php?ID=$filaNoticia[NoticiasID]&amp;Titulo=$filaNoticia[Titulo]&amp;Video=$filaNoticia[Video]&amp;Texto=$filaNoticia[Texto]&amp;Foto=$filaNoticia[Foto]&amp;CategoriaID=$filaNoticia[CategoriaID]&amp;'>...Seguir leyendo</a>";  
    }    
?>
Código HTML:
es la primera entrando
[url]http://localhost/PRINCIPAL/php/SitiosWeb/TiendaVirtual/index.php[/url]

es la segunda dando clic en musica link (muestra articulos de musica solo)
[url]http://localhost/PRINCIPAL/php/SitiosWeb/TiendaVirtual/index.php?categoria=Musica&id=6[/url]

es la tercera dando clic en videojuegos link (muestra articulos de videojuegos solo)
[url]http://localhost/PRINCIPAL/php/SitiosWeb/TiendaVirtual/index.php?categoria=Videojuegos&id=5[/url]

le doy clic a un link de el titulo del articulo de videojuegos y me carga todos los articulos de todas 
[url]http://localhost/PRINCIPAL/php/SitiosWeb/TiendaVirtual/index.php?ID=2&Titulo=El%20verdadero%20terror%20llega%20desde%20Indonesia%20%20&Video=%3Ciframe%20width=%22560%22%20height=%22315%22%20src=%22http://www.youtube.com/embed/OQCCOZLOimw%22%20frameborder=%220%22%20allowfullscreen%3E%3C/iframe%3E&Texto=En%20este%20sentido,%20cabe%20citar%20el%20pr%EF%BF%BDximo%20advenimiento%20de%20DreadOut,%20un%20survival%20horror%20programado%20por%20Digital%20Happiness%20para%20Windows,%20Linux%20y%20Mac.%20Una%20de%20sus%20principales%20particularidades%20es%20la%20de%20estar%20siendo%20realizado%20en%20Indonesia,%20cualidad%20que%20le%20aporta%20un%20exotismo%20digno%20de%20rese%EF%BF%BDar.%20Por%20lo%20dem%EF%BF%BDs,%20este%20desarrollo%20se%20encuentra%20ahora%20mismo%20tanto%20en%20Greenlight%20como%20en%20la%20plataforma%20crowfunding%20Indiegogo,%20luchando%20por%20asomar%20la%20cabeza%20y%20convencer%20al%20p%EF%BF%BDblico%20de%20que%20de%20verdad%20va%20a%20merecer%20la%20pena.%20Para%20demostrarlo,%20Digital%20Happiness%20ha%20dispuesto%20de%20una%20demo%20jugable%20que%20ense%EF%BF%BDa%20de%20qu%EF%BF%BD%20va%20la%20cosa,%20mostr%EF%BF%BDndonos%20algo%20muy%20cercano%20al%20cl%EF%BF%BDsico%20Project%20Zero%20que,%20todo%20hay%20que%20decirlo,%20nos%20deja%20con%20ganas%20de%20m%EF%BF%BDs.%20%EF%BF%BDApostamos%20por%20el%20terror%20indonesio?M%EF%BF%BDs%20informaci%EF%BF%BDn:%20http://www.mundogamers.com/noticia-el-verdadero-terror-llega-desde-indonesia.2089.htmlCopyright%20%EF%BF%BD%20MundoGamers.com&Foto=imagenes/el_verdadero_terror_llega_desde_indonesia_1.jpg&CategoriaID=5&[/url]
  #4 (permalink)  
Antiguo 10/04/2013, 03:20
Avatar de hades87  
Fecha de Ingreso: diciembre-2007
Ubicación: Barcelona - España
Mensajes: 3.194
Antigüedad: 16 años, 11 meses
Puntos: 68
Respuesta: variables por get en links

Has verificado que la query a la base de datos se te este creando bien? de que realmente estés haciéndola correcta adecuada con todos los datos? tirala en el phpmyAdmin lo que te devuelve el php
__________________
No diseñes usando tablas.
  #5 (permalink)  
Antiguo 10/04/2013, 03:29
Avatar de CMushroom  
Fecha de Ingreso: diciembre-2011
Ubicación: Morelos
Mensajes: 99
Antigüedad: 12 años, 10 meses
Puntos: 1
Pregunta Respuesta: variables por get en links

Cita:
Iniciado por hades87 Ver Mensaje
Has verificado que la query a la base de datos se te este creando bien? de que realmente estés haciéndola correcta adecuada con todos los datos? tirala en el phpmyAdmin lo que te devuelve el php
articulo.php
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title><?php $Titulo $_GET['Titulo']; echo  $Titulo ?></title>
</head>  
    
<body>
<?php include('Header.php'); ?>

<div style = "float:left; width: 23%;">
<?php include('ListaCategoria.php'); ?>
<?php 
include('Administrador.php'); ?>
</div>

<div style = "float:left; width: 54%;">
<?php include('Noticia.php'); ?>
</div>

<div style = "float:right; width: 23%;">
<?php include('list-imagenes.php'); ?>
</div>

</body>
</html>
Noticia.php
Código PHP:
<?php 
$clausula 
"";
if(isset(
$_GET['ID']) && $_GET['Titulo'] && $_GET['Texto']&& $_GET['Foto'] && $_GET['Video']&& $_GET['CategoriaID'])
    {
    
$ID $_GET['ID'];
    
$clausula "WHERE NoticiasID = '$ID'";
    }

include (
'Conexion.php');
$Select mysql_query("SELECT * FROM noticias $clausula"$LinkBaseDatos) or die(mysql_error);
include (
'CerrarConexion.php');
 
while(
$filaNoticia mysql_fetch_array($Select))
    {
    echo 
'<h2>'.$filaNoticia['Titulo'].'</h2>';
    echo 
$filaNoticia['Subtitulo']."  ".$filaNoticia['Fecha'].'<br><br>';
    echo 
"<center><img src = '$filaNoticia[Foto]' height='200'></center><br>";
    echo 
$filaNoticia['Texto'].'<br><br>';  
    echo 
'<center>'.$filaNoticia['Video'].'</center>';
    }
        
include (
'Comentarios.php');
sql
Código PHP:
--
-- 
Base de datos: `scriptsistemanoticias`
--

-- --------------------------------------------------------

--
-- 
Estructura de tabla para la tabla `categorias`
--

CREATE TABLE IF NOT EXISTS `categorias` (
  `
CategoriasIDint(11NOT NULL AUTO_INCREMENT,
  `
Categoriasvarchar(100NOT NULL,
  
PRIMARY KEY (`CategoriasID`)
ENGINE=MyISAM  DEFAULT CHARSET=latin1 ;

--
-- 
Volcar la base de datos para la tabla `categorias`
--

INSERT INTO `categorias` (`CategoriasID`, `Categorias`) VALUES
(1'Arte'),
(
2'Cultura'),
(
3'Informatica'),
(
4'Deportes'),
(
5'Videojuegos'),
(
6'Musica');

--
-- 
Estructura de tabla para la tabla `comentarios`
--

CREATE TABLE IF NOT EXISTS `comentarios` (
  `
firma_IDint(11NOT NULL AUTO_INCREMENT,
  `
usuariovarchar(25NOT NULL,
  `
firmatext NOT NULL,
  `
fechavarchar(34NOT NULL,
  
PRIMARY KEY (`firma_ID`)
ENGINE=MyISAM  DEFAULT CHARSET=latin1 ;


--
-- 
Estructura de tabla para la tabla `noticias`
--

CREATE TABLE IF NOT EXISTS `noticias` (
  `
NoticiasIDint(11NOT NULL AUTO_INCREMENT,
  `
Fotovarchar(255NOT NULL,
  `
Videovarchar(255NOT NULL,
  `
Titulovarchar(255NOT NULL,
  `
Subtitulovarchar(255NOT NULL,
  `
Textotext NOT NULL,
  `
Fechadatetime NOT NULL,
  `
ComentarioIDint(11NOT NULL,
  `
MegustaIDint(11NOT NULL,
  `
CategoriaIDint(11NOT NULL,
  
PRIMARY KEY (`NoticiasID`)
ENGINE=MyISAM  DEFAULT CHARSET=latin1  
Conexion.php
Código PHP:
<?php
$LinkBaseDatos 
mysql_connect('localhost''root''');

if(! 
$LinkBaseDatos)
    {
    die(
'No se pudo conectar: ' mysql_error());
    }
    
$BaseDatosSeleccionada mysql_select_db('scriptsistemanoticias'$LinkBaseDatos);

if(! 
$BaseDatosSeleccionada)
    {
    die(
'No se existe la BD: ' mysql_error());
    }
?>
CerrarConexion.php
Código PHP:
<?php
mysql_close
($LinkBaseDatos);
?>
AgregarNoticia.php
Código PHP:
<?php
if(isset($_POST['enviar']) && $_POST['enviar'] == 'Enviar')
    {
    if(!empty(
$_POST['Titulo']) && $_POST['Texto'] && $_POST['CategoriaID'])
        {
        
$Titulo htmlentities(trim($_POST['Titulo']));
        
$Texto htmlentities(trim($_POST['Texto']));
        
        
$nombre_archivo $_FILES['Foto']['name'];
        
$tamaño_archivo $_FILES['Foto']['size'];
        
$tipo_archivo $_FILES['Foto']['type'];
        
$ruta_archivo "imagenes/$nombre_archivo";
        
$Video $_POST['Video'];
        
        
$Fecha $_POST['Fecha'];
        
$CategoriaID $_POST['CategoriaID'];

        if (
$tamaño_archivo 5000000)
            {
            @
$mensaje $mensaje." El archivo es demasiado grande. El límite es 5 Mb<br>";
            echo 
$mensaje;
            
$subir_archivo "false";
            }
        
        if (!(
$tipo_archivo == "image/jpeg" OR $tipo_archivo == "image/gif" OR $tipo_archivo == "image/png" OR $tipo_archivo == "image/bmp") && $nombre_archivo != "")
            {
            @
$mensaje $mensaje." El archivo tiene que ser JPG, GIF, PNG, o BMP. Otros archivos no son permitidos<br>";
            echo 
$mensaje;
            
$subir_archivo "false";
            }
            
        if(
move_uploaded_file($_FILES['Foto']['tmp_name'], $ruta_archivo))//ruta temporal pasa a directorio
            
{
            echo 
"<img src='".$ruta_archivo."' height='200'><br>";
            }
            
        else
            {
            echo 
" Error al subir el archivo ";
            }
            
        include (
'Conexion.php');
        
$Insert mysql_query("INSERT INTO Noticias(Titulo, Video, Foto, Texto, Fecha, CategoriaID) VALUES ('$Titulo', '$Video', '$ruta_archivo', '$Texto', '".date(" Y-m-d-H:i:s")."', '$CategoriaID')",$LinkBaseDatos) or die(mysql_error());
        include (
'CerrarConexion.php');
        echo 
"<br>Los datos fueron guardados correctamente";
        }
    else
        {
        echo 
"<br>Debe llenar todos los campos del formulario";
        }
    }
?>
<form enctype = "multipart/form-data" name = "FormularioCategoria" action = "<?php $_SERVER['PHP_SELF']; ?>" method = "POST">
    <p>
    Titulo de la Noticia<br />
    <input type = "text" name = "Titulo" size="50" />
    </p>
    <input type="hidden" name="MAX_FILE_SIZE" value="5000000" />
    <p>
    Imagen de la Noticia<br />
    <input type="file" name = "Foto" />
    </p>
    <p>
    Video de la Noticia<br />
    <input type = "text" name = "Video" size="50" />
    </p>
    <p>
    Texto de la Noticia<br />
    <textarea name = "Texto" rows="10" cols="50"></textarea>
    </p>
    <p>
    Fecha de la Noticia<br />
    <input type = "text" name = "Fecha" size="50" />
    </p>
    <p>
    Categoria<br />
    <select name = "CategoriaID">
        <option value = "">Escoger de la Lista</option>
        <?php
        
include ('Conexion.php');
        
$Select mysql_query("SELECT * FROM categorias"$LinkBaseDatos) or die(mysql_error);
        include (
'CerrarConexion.php');
        
        while(
$Fila mysql_fetch_array($Select))
            {
            echo 
"<option value = '$Fila[CategoriasID]'>$Fila[Categorias] - $Fila[CategoriasID]</option>";
            }
        
?>
    </select>
    </p>
    <p>
    <input type = "submit" name = "enviar" value = "Enviar" />
    </p>
</form>
aqui esta todo parta que lo pruebes porfavor

Etiquetas: html, links, mysql, select, sql, variables
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 21:37.