Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Temas - den_22

#1
PHP / Paginador de resultados ayuda!
15 Mayo 2010, 17:47 PM
Hola! que tal, verán estoy tratando de hacer un paginador de resultados de un buscador de usuarios, pero lamentablemente no me sale, tengo este codigo, que es el mostrar_resultados.php, pero al hacer la busqueda en vez de mostrar 5 resultados me muestra 6, y al pasar a siguiente, me muestra todos los usuarios de la bd.
Entonces la pregunta es cómo hago para poder paginarlo bien?, hay algo que estoy haciendo mal? cuando la pagina ya existe como hago para cargarla y que siga manteniendo la consulta?

Código (php) [Seleccionar]

<?php
include('header.inc');


if(!
$_SESSION['usuario']=='usuario'){
header("Location: index.php");// si no es igual a nick te direcciona al inicio u a otra pagina 
}

include_once (
"connect.php");

$id=$_SESSION["id"];
$usuario=$_SESSION["usuario"];


$sexo = (!empty($_POST["sexo"])
    ? 
" sexo='".trim($_POST["sexo"])."'"
        
"");
 
$interestin = (!empty($_POST["interestin"])
        ? (!empty(
$sexo)
                ? 
" AND interestin='".trim($_POST["interestin"])."'"
                
" interestin='".trim($_POST["interestin"])."'")
        : 
"");
 
$pais = (!empty($_POST["pais"])
        ? (!empty(
$sexo) || !empty($interestin)
                ? 
" AND pais='".trim($_POST["pais"])."'"
                
" pais='".trim($_POST["pais"])."'")
        : 
"");
 
$estadocivil= (!empty($_POST["estadocivil"])
        ? (!empty(
$sexo) || !empty($interestin) || !empty($pais)
                ? 
" AND estadocivil='".trim($_POST["estadocivil"])."'"
                
" estadocivil='".trim($_POST["estadocivil"])."'")
        : 
"");
 

 
$where = (!empty($sexo) || !empty($interestin) || !empty($pais) || !empty($estadocivil)  
        ? 
" WHERE "
        
"");
 

 
$s "SELECT * FROM members " 
        
$where
        
$sexo 
        
$interestin
        
$pais 
        
$estadocivil;
 
$query mysql_query($s) or die(mysql_error());

if (!isset(
$pag)) $pag 1// Por defecto, pagina 1
$result mysql_query("SELECT COUNT(*) FROM members"); 
list(
$total) = mysql_fetch_row($result);
$tampag 5;
$reg1 = ($pag-1) * $tampag;
$result mysql_query("SELECT sexo, interestin, pais, estadocivil FROM members
  LIMIT 
$reg1$tampag"); 


function 
paginar($actual$total$por_pagina$enlace) {
  
$total_paginas ceil($total/$por_pagina);
  
$anterior $actual 1;
  
$posterior $actual 1;
  if (
$actual>1)
    
$texto "<a href=\"$enlace$anterior\">&laquo;</a> ";
  else
    
$texto "<b>&laquo;</b> ";
  for (
$i=1$i<$actual$i++)
    
$texto .= "<a href=\"$enlace$i\">$i</a> ";
  
$texto .= "<b>$actual</b> ";
  for (
$i=$actual+1$i<=$total_paginas$i++)
    
$texto .= "<a href=\"$enlace$i\">$i</a> ";
  if (
$actual<$total_paginas)
    
$texto .= "<a href=\"$enlace$posterior\">&raquo;</a>";
  else
    
$texto .= "<b>&raquo;</b>";
  return 
$texto;
}



while(
$row mysql_fetch_array($query)) {




?>


en la parte del html, muestro los detalles del usuario haciendo
Código (php) [Seleccionar]
<?php echo $row['estadocivil'];?> por ejemplo

y en el final de la pagina hago lo siguiente

Código (php) [Seleccionar]
<?php echo paginar($pag$total$tampag"mostrar_resultados.php?pag="); ?>

Gracias por leer.
#2
PHP / Añadir y eliminar contactos problema
30 Abril 2010, 21:17 PM
Hola que tal, veran estoy haciendo un eliminar y mostrar contactos de cada usuario; el problema que me surge es que me muestra todas los usuarios que hay; y el $cnt me dice por ejemplo tienes 3 usuarios, todo bien, pero en la lista salen todos los que hay y no esos 3.
Tampoco se eliminan los usuarios que uno quiere eliminar.
Dejo el codigo por las dudas.

Código (php) [Seleccionar]
<?php
 error_reporting
(E_ALL E_NOTICE);
session_name('pLogin');
session_set_cookie_params(2*7*24*60*60);
session_start();
include(
"connect.php");

$usuario=$_SESSION['usuario'];
$tid=$_GET["id"];
$id=$_SESSION["id"];

$msg1="";
$to_delete="";
$items_removed=0;
if ( 
count($_POST)<>)
{
/////////////////////////// A REQUEST TO DELETE SOME CONTACTS ///////////////

for($i=1;$i<=$_REQUEST["cnt"];$i++)
{
 
if ( isset(
$_REQUEST["checkbox" $i]) )  //Is the checkbox ticked
{
if (
$to_delete!="") { $to_delete.="," ; }  //To insert comma??
$to_delete.= $_REQUEST["checkbox" $i];  //Add another item to delete
$items_removed++;
}

//End For
if ($to_delete=="")
{
$msg1=" No se puede eliminar ningun usuario de la lista de contactos ";
}
else
{
$del_str="  Delete from dm_contacts where dm_contact_id IN (" $to_delete .")";
mysql_query($del_str);
$msg1= ($items_removed 1)?$items_removed " Usuarios que han sido removidos de tu lista de contactos":$items_removed " El usuario ha sido removido de tu lista";
}
header("Location:"." msg_confirm_mem.php?errmsg=".urlencode($msg1));
die();
/////////////////////////////CONTACTS HAVE BEEN REMOVED /////////////////////
}



$rs0_query=mysql_query("Select count(*) from dm_contacts  where  dm_uid =" .$tid );
$rs0=mysql_fetch_array($rs0_query);
$contact_count=$rs0[0];

$rs0_query=mysql_query("SELECT * FROM dm_contacts, members WHERE dm_contacts.dm_contact_id=members.id" );
?>

<script language="javascript">
function validate(form)
{
if((form.username.value==""))
{
alert('Por favor especifica un nombre de usuario');
form.username.focus();
return false;
}
return true;
}
</script>
<table width="100%" border="0" cellpadding="0" cellspacing="0" >
  <tr>
    <td colspan="3" valign="top"><table width="90%" border="0" align="center" cellpadding="0" cellspacing="0">
        <tr>
          <td><table width="100%" border="0" cellspacing="0" cellpadding="0">
              <tr>
                <td class="titlestyle">&nbsp;Añadir a mi lista de contactos</td>
              </tr>
            </table></td>
        </tr>
        <tr>
          <td><table width="100%" border="0" align="center" cellpadding="2" cellspacing="5" class="onepxtable">
              <form name="form1" method="post" action="addcontact.php" onSubmit="return validate(this);">
                <tr valign="top">
                  <td width="40%" align="right" class="innertablestyle"><table width="100%" border="0" cellspacing="0" cellpadding="0">
                      <tr align="right">
                        <td width="60%"><font class="normal"><strong><font class='normal'>
                          </font></strong></font></td>
                        <td><font class="normal"><strong><font class='normal'>Username</font></strong></font></td>
                      </tr>
                    </table></td>
                  <td width="6">&nbsp;</td>
                  <td width="60%"><font face="Arial, Helvetica, sans-serif" size="2">
                    <input type="text" name="username">
                    </font></td>
                </tr>
                <tr valign="top">
                  <td align="right" class="innertablestyle">&nbsp;</td>
                  <td>&nbsp;</td>
                  <td><input type="submit" name="Submit2" value="Add User"></td>
                </tr>
              </form>
            </table></td>
        </tr>
      </table>
     
    </td>
  </tr>
  <tr>
    <td height="25" colspan="3" valign="middle"> <div align="center"><font class='red'>
        </font></div></td>
  </tr>
  <tr>
    <td valign="top"><table width="100%" border="0" cellspacing="0" cellpadding="0">
        <tr>
          <td valign="top"> <table width="90%" border="0" align="center" cellpadding="0" cellspacing="0" class="onepxtable">
              <tr >
                <td valign="top"> <table width="100%" border="0" align="center" cellpadding="2" cellspacing="0" class="innertablestyle">
                    <tr>
                      <td height="25" class="titlestyle">&nbsp;Mis contactos</td>
                    </tr>
                    <tr>
                      <td height="25" valign="middle"><font class='normal'>Tu lista de contactos tiene <strong><font class='red'><?php echo $contact_count?></font></strong><?php
if( $contact_count>1)
{
echo " usuarios";
}
else
{
echo " usuario";
}
?>
</font><font class='red'><br>
                        </font></td>
                    </tr>
                    <tr>
                      <td height="25" valign="middle"><font class='normal'>To
                        remove a user from my contacts list just check the check
                        box and click the remove button below.</font></td>
                    </tr>
                    <tr>
                      <td valign="top">
  <script language="javascript">
//<!--
function select_all()
{
  for (var i=0;i<document.form2.elements.length;i++)
  {
var e =document. form2.elements[i];
if ((e.name != 'check_all') && (e.type=='checkbox'))
{
   e.checked = document.form2.check_all.checked;
}
  }
}
function validate_rem(form)
{
var checked='no';
  for (var i=0;i<form.elements.length;i++)
  {
var e =form.elements[i];
if (e.checked==true)
{
   checked='yes';
}
  }
if(checked=='no')
{
alert('Por favor elige al menos un contacto a eliminar');
return false;
}
return true;
}
//-->
</script>
<form name="form2" method="post" action="mostrarcontactos.php" onSubmit="return validate_rem(this);">
                          <table width="100%" border="0" align="center" cellpadding="2" cellspacing="1">
                            <tr class="subtitle">
                              <td width="10" align="right"> <input name="check_all" type="checkbox" id="check_all" onClick="select_all();" value="yes"></td>
                              <td height="25"><b><font class='normal'>Usuario</font></b></td>
                              <!--td><b><font class='normal'>Company Name </font></b></td>
                              <td><b><font class='normal'>Phone</font></b></td>
                              <td><b><font class='normal'>Fax</font></b></td-->
                            </tr>
                            <?php
$cnt=0;
while ($rs0=mysql_fetch_array($rs0_query))
{
  $cnt++;

  
  
?>

                            <tr>
                              <td width="10" align="right" ><font class='normal'>
                                <input type="checkbox" name="checkbox<?php echo $cnt;?>" value="<?php
   echo $rs0["dm_uid"];?>
">
                                </font></td>
                              <td ><font class='normal'><a href="replyuser.php?type=contact&tid=<?php echo $rs0["dm_contact_id"];?>" ><?php echo $rs0["usuario"];?></a>
                                </font></td>

                            </tr>
                            <?php
}
?>

                            <tr >
                              <td colspan="2" align="left"> <input type="hidden" name="cnt" value="<?php echo $cnt?>">
                                <input type="submit" name="Submit3" value="Remove">
                              </td>
                              <!--td>&nbsp;</td>
                              <td>&nbsp;</td>
                              <td>&nbsp;</td-->
                            </tr>
                          </table>
                        </form></td>
                    </tr>
                  </table></td>
              </tr>
            </table></td>
        </tr>
        <tr>
          <td>&nbsp;</td>
        </tr>
      </table></td>
  </tr>
</table>


el dm_uid-> es la id del usuario de la sesion
el dm_contacts_id-> es la id del contacto añadido.


Gracias de antemano
#3
Hola que tal, les comento tengo este codigo para subir imagenes, todo bien se hace la insercion a la bd, pero que pasa... me gustaria poder redimensionar esas imagenes para que se muestren por ejemplo en el perfil. Cómo se podria usar la libreria en este codigo?, o se usa aparte. Alguien podria guiarme?

Gracias de antemano, den_22

Dejo el codigo:

Código (php) [Seleccionar]

<?php
error_reporting
(E_ALL E_NOTICE);
session_name('pLogin');
session_set_cookie_params(2*7*24*60*60);
session_start();

include(
"connect.php");


$id=$_SESSION['id'];


 
define ("MAX_SIZE","500"); 


 function 
getExtension($str) {
         
$i strrpos($str,".");
         if (!
$i) { return ""; }
         
$l strlen($str) - $i;
         
$ext substr($str,$i+1,$l);
         return 
$ext;
 }



 
$errors=0;

 if(isset(
$_POST['Submit'])) 
 {
 

 
$image=$_FILES['image']['name'];
 

 
if ($image
 
{

 
$filename stripslashes($_FILES['image']['name']);
 
  
$extension getExtension($filename);
 
$extension strtolower($extension);

 if ((
$extension != "jpg") && ($extension != "jpeg") && ($extension != "png") && ($extension != "gif")) 
 
{
//print error message
 
echo '<h1>No es una imagen!</h1>';
 
$errors=1;
 
}
 
else
 
{



 
$size=filesize($_FILES['image']['tmp_name']);

//comparamos el tamaño definido con este
if ($size MAX_SIZE*1024)
{
echo '<h1>Has excedido el limite permitido!</h1>';
$errors=1;
}


$image_name=time().'.'.$extension;

$newname="images/".$image_name;
//verificamos si se subió la imagen, e imprimimos el error en todo caso
$copied copy($_FILES['image']['tmp_name'], $newname);
if (!
$copied
{
echo '<h1>No se ha podido subir la imagen!</h1>';
$errors=1;
}}}}

//Si no hay errores imprimir el mensaje 
 
if(isset($_POST['Submit']) && !$errors
 {
 
echo "<h1>El archivo subió correctamente</h1>";
mysql_query("
UPDATE prueba
SET picture='
$image_name'
WHERE id='
$_SESSION[id]'  ");
 }



#4
PHP / Haciendo un buscador
3 Abril 2010, 04:59 AM
Hola que tal, estoy tratando de hacer un buscador tengo este archivo search.php, que la parte del php es algo asi:

Código (php) [Seleccionar]

<?
error_reporting(E_ALL ^ E_NOTICE);
session_name('pLogin');
session_set_cookie_params(2*7*24*60*60);
session_start();

include("function.php");
include("connect.php");
include("getdata.php");

$query = mysql_query("select * from prueba where usuario='$usuario'");
   $getname = mysql_fetch_array($query);
   $firstname = $getname["firstname"];
   $lastname =$getname["lastname"];
   $gender= $getname["sexo"];
   $estadocivil=$getname["estadocivil"];
   $pais=$getname["pais"];
?>


y la parte del html asi


Código (php) [Seleccionar]
<table width="470" height="254" border="1">
<form action="search_results.php" method="post">
  <tr>
    <td width="189">Nombre:</td>
    <td width="265"><?php echo $firstname;?><input type="text" name="firstname" class="main_text_normal" style="width: 100%;"></td>
  </tr>
  <tr>
    <td>Apellido:</td>
    <td><?php echo $lastname;?><input type="text" name="lastname" class="main_text_normal" style="width: 100%;"></td>
  </tr>
  <tr>
    <td>Pais:</td>
    <td><select size=1 NAME='pais'>
         
          <option <?php if ($user_ok[pais]=="Argentina") echo "selected"?>>Argentina</option>
          <option <?php if ($user_ok[pais]=="Bolivia") echo "selected"?>>Bolivia</option>
          <option <?php if ($user_ok[pais]=="Chile") echo "selected"?>>Chile</option>
  <option <?php if ($user_ok[pais]=="Costa Rica") echo "selected"?>>Costa Rica</option>
  <option <?php if ($user_ok[pais]=="Cuba") echo "selected"?>>Cuba</option>
  <option <?php if ($user_ok[pais]=="Ecuador") echo "selected"?>>Ecuador</option>
  <option <?php if ($user_ok[pais]=="El Salvador") echo "selected"?>>El Salvador</option>
  <option <?php if ($user_ok[pais]=="Espana") echo "selected"?>>Espana</option>
  <option <?php if ($user_ok[pais]=="Guatemala") echo "selected"?>>Guatemala</option>
  <option <?php if ($user_ok[pais]=="Guinea Ecuatorial") echo "selected"?>>Guinea Ecuatorial</option>
  <option <?php if ($user_ok[pais]=="Honduras") echo "selected"?>>Honduras</option>
  <option <?php if ($user_ok[pais]=="México") echo "selected"?>>México</option>
  <option <?php if ($user_ok[pais]=="Nicaragua") echo "selected"?>>Nicaragua</option>
  <option <?php if ($user_ok[pais]=="Panamá") echo "selected"?>>Panamá</option>
  <option <?php if ($user_ok[pais]=="Paraguay") echo "selected"?>>Paraguay</option>
  <option <?php if ($user_ok[pais]=="Perú") echo "selected"?>>Perú</option>
  <option <?php if ($user_ok[pais]=="Puerto Rico") echo "selected"?>>Puerto Rico</option>
  <option <?php if ($user_ok[pais]=="República Dominicana") echo "selected"?>>República Dominicana</option>
  <option <?php if ($user_ok[pais]=="Uruguay") echo "selected"?>>Uruguay</option>
  <option <?php if ($user_ok[pais]=="Venezuela") echo "selected"?>>Venezuela</option>
        </select> </td>
  </tr>
  <tr>
    <td>Estado Civil: </td>
    <td><select size=1 NAME='estadocivil'>
          <option></option>
          <option <?php if ($user_ok[estadocivil]=="Soltero/a") echo "selected"?>>Soltero/a</option>
          <option <?php if ($user_ok[estadocivil]=="Divorciado/a") echo "selected"?>>Divorciado/a</option>
  </select></td>
  </tr>
  <tr>
    <td>Genero:</td>
    <td><select size=1 NAME='sexo'>
          <option></option>
          <option <?php if ($user_ok[sexo]=="Masculino") echo "selected"?>>Masculino</option>
          <option <?php if ($user_ok[sexo]=="Femenino") echo "selected"?>>Femenino</option>
         
        </select></td>
  </tr>
  </form>


ahora bien, al hacer click en buscar, llama al archivo search_results.php que es el siguiente:


Código (php) [Seleccionar]

<?

error_reporting(E_ALL ^ E_NOTICE);

session_name('pLogin');
session_set_cookie_params(2*7*24*60*60);
session_start();
include('connect.php');
$usuario = $_SESSION['usuario'];

$firstname=$_POST['firstname'];
$lastname=$_POST['lastname'];
$estadocivil=$_POST['estadocivil'];
$gender=$_POST['sexo'];
$pais=$_POST['pais'];



$query= mysql_query("select * from prueba where firstname='".$firstname."' AND lastname='".$lastname."'AND sexo='".$gender."' AND estadocivil='".$estadocivil."' AND pais='".$pais."'");
   


?>



en el html de este archivo hago un <?php echo $firstname;?>, por ejemplo.

Mi pregunta es, en qué estoy fallando porque no me busca ningun usuario. Está bien como lo estoy haciendo?

De antemano gracias, solo busco algo de orientacion.
#5
PHP / Perfil de un usuario, problema!
5 Marzo 2010, 04:44 AM
Hola que tal, estoy haciendo un modificar perfil. La cuestion es que quiero que el usuario al presionar sobre modificar perfil le aparezcan algunos datos que completó en el registro, y los demás deba rellenarlo.
Tengo un Warning en la linea 11 del getdata.php:"mysql_fetch_array(): supplied argument is not a valid MySQL result resource"

Lo que tengo hasta ahora es lo siguiente:

modificarperfil.php:
Código (php) [Seleccionar]
<?php
 
include("function.php");
include(
"getdata.php");
include(
"connect.php"); //incluimos el connect.php que contiene los datos de la conexión a la db y la sesión
 
if(!isset($_GET['usuario'])){
echo 
'No se ha seleccionado ningun usuario.'
}else{
 
 
$query=mysql_query("SELECT * FROM prueba WHERE usuario=$usuario ");
if(
mysql_num_rows($usuario)>0){
$query=mysql_fetch_array($usuario);
 
//todo comprobado, ahora solo falta mostrar los datos
echo 'Bienvenid@ <b>'.$usuario[usuario].'</b><br>';
 
 
}else{
 
echo 
'El usuario seleccionado no existe';
}
}
?>



El function.php:

Código (php) [Seleccionar]
<?php
 
 
 
 
function getfname($usuario)
{
    
$query mysql_query("select * from prueba where usuario=$usuario");
    
$getnamemysql_fetch_array($query);
    
$firstname$getname["firstname"];
    return 
$firstname;
}
 
function 
getlname($usuario)
{
    
$query =mysql_query("select * from prueba where usuario=$usuario");
    
$getnamemysql_fetch_array($query);
    
$lastname=$getname["lastname"];
    return 
$lastname;
}
 
 
function 
getusuario($usuario)
{
    
$query=mysql_query("select * from prueba where usuario=$usuario");
    
$getname=mysql_fetch_array($query);
    
$usuario=$getname["usuario"];
    return 
$usuario;
}
 
function 
getgender ($usuario)
{
    
$query=mysql_query("select * from prueba where usuario=$usuario");
    
$getname=mysql_fetch_array($query);
    
$gender=$getname["Genero"];
    return 
$gender;
}
 
 
 
 
?>



El getdata.php:

Código (php) [Seleccionar]
<?php
 
 
 
include "connect.php";
 
$query=mysql_query("select * from prueba where usuario=$usuario");
$getname=mysql_fetch_array($query);  //linea 11 aqui esta el warning
 
$firstname=$getname["firstname"];
$lastname=$getname["lastname"];
$usuario=$getname["usuario"];
$gender=$getname["genero"];
 
 
?>



Lo que yo quiero es que me aparezcan en el formulario los datos a los que consulta en la bd.
En el formulario lo hago de esta forma:
Código (php) [Seleccionar]
<tr>
      <td width="219">Nombre:</td>
      <td width="270"><input name="firstname" type="text" id="firstname" value="<?php echo $firstname;?>"></td>
    </tr>


Esta es la base de datos, al hacer la consulta me devuelve un valor vacio, pero está completo ese valor.

Código (sql) [Seleccionar]
CREATE TABLE `prueba` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
`firstname` varchar(32) collate utf8_unicode_ci NOT NULL DEFAULT '',
`lastname` varchar(40) collate utf8_unicode_ci NOT NULL DEFAULT '',
  `usuario` varchar(32) collate utf8_unicode_ci NOT NULL DEFAULT '',
  `pass` varchar(32) collate utf8_unicode_ci NOT NULL DEFAULT '',
`sexo` varchar (32) collate utf8_unicode_ci NOT NULL DEFAULT '',
  `email` varchar(255) collate utf8_unicode_ci NOT NULL DEFAULT '',
  PRIMARY KEY  (`id`),
  UNIQUE KEY `usuario` (`usuario`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;



Gracias por leerlo, den_22
#6
PHP / Problema con estos códigos
1 Marzo 2010, 17:00 PM
Hola ! que tal, estoy con un "pequeño problemita" la cuestión es la siguiente. Quiero hacer un apartado de un panel de control para modificar un perfil.
Tengo los siguientes códigos:
El modificarperfil.php

Código (php) [Seleccionar]
<?php
session_start
();
include(
"function.php");
include(
"getdata.php");
include(
"connect.php"); //incluimos el connect.php que contiene los datos de la conexión a la db y la sesión
 
if(!isset($_GET['usuario'])){
echo 
'No se ha seleccionado ningun usuario.'//no ha seleccionado usuario,
}else{
 
//comprobamos si esa id existe
$query=mysql_query("SELECT * FROM prueba WHERE usuario=$usuario ");
if(
mysql_num_rows($usuario)>0){
$query=mysql_fetch_array($usuario);
 
//todo comprobado, ahora solo falta mostrar los datos
echo 'Bienvenid@ <b>'.$usuario[usuario].'</b><br>';
 
 
}else{
 
echo 
'El usuario seleccionado no existe';
}
}
?>




A su vez en la tabla de modificar perfil pongo lo siguiente para obtener los datos de la bd:
Código (php) [Seleccionar]
<td width="292"><input name="firstname" type="text" id="firstname" value="<?php echo $firstname;?>"></td>

El function.php:
Código (php) [Seleccionar]
<?php
session_start
();
function 
getfname($id)
{
$query mysql_query("select * from prueba where id=$id");
$getnamemysql_fetch_array($query);
$firstname$getname["firstname"];
return $firstname;
}

function 
getlname($id)
{
$query =mysql_query("select * from prueba where id=$id");
$getnamemysql_fetch_array($query);
$lastname=$getname["lastname"];
return $lastname;
}


function 
getusuario($id)
{
$query=mysql_query("select * from prueba where id=$id");
$getname=mysql_fetch_array($query);
$usuario=$getname["usuario"];
return $usuario;
}

function 
getgender ($id)
{
$query=mysql_query("select * from prueba where id=$id");
$getname=mysql_fetch_array($query);
$gender=$getname["Genero"];
return $gender;
}




?>



El getdata.php:

Código (php) [Seleccionar]
<?php
session_start
();
include 
"connect.php";

$query=mysql_query("select * from prueba where id=$id");
$getname=mysql_fetch_array($query);

$firstname=$getname["firstname"];
$lastname=$getname["lastname"];
$usuario=$getname["usuario"];
$gender=$getname["genero"];


?>



El connect.php:
Código (php) [Seleccionar]
<?php

if(!defined('INCLUDE_CHECK')) die('No estás autorizado a ejecutar este archivo directamente');


/* Database config */

$db_host 'localhost';
$db_user 'user';
$db_pass 'xxxx';
$db_database 'prueba'

/* End config */



$link mysql_connect($db_host,$db_user,$db_pass) or die('Imposible establecer la conexión a la base de datos');

mysql_select_db($db_database,$link);
mysql_query("SET names UTF8");

?>



El error que me tira todo esto es que "No estás autorizado  a ejecutar este archivo directamente"

Gracias de antemano por tomarse el trabajo de leerlo. :)
#7
PHP / Como hago con este codigo?
10 Febrero 2010, 23:43 PM
Hola, tengo una pregunta acerca de este código, la cuestion es que al querer hacer el registro siempre en el formulario, me dice "This username has already taken",ademas si no se registra en la bd, como ya va a estar siendo usado?. :huh:
Dejo el código a ver si me pueden dar una mano.(La parte en negrita calculo que debe estar provocando esto)

<?php
error_reporting
(E_ALL E_NOTICE);
session_start();

define('INCLUDE_CHECK',true);

require 
'connect.php';
require 
'functions.php';
// Those two files can be included only if INCLUDE_CHECK is defined


session_name('tzLogin');
// Starting the session

session_set_cookie_params(2*7*24*60*60);
// Making the cookie live for 2 weeks

session_start();

if(
$_SESSION['id'] && !isset($_COOKIE['tzRemember']) && !$_SESSION['rememberMe'])
{
// If you are logged in, but you don't have the allnurseRemember cookie (browser restart)
// and you have not checked the rememberMe checkbox:

$_SESSION = array();
session_destroy();

// Destroy the session
}


if(isset(
$_GET['logoff']))
{
$_SESSION = array();
session_destroy();

header("Location: demo.php");
exit;
}

if(
$_POST['submit']=='Login')
{
// Checking whether the Login form has been submitted

$err = array();
// Will hold our errors


if(!$_POST['username'] || !$_POST['password'])
$err[] = 'All the fields must be filled in!';

if(!count($err))
{
$_POST['username'] = mysql_real_escape_string($_POST['username']);
$_POST['password'] = mysql_real_escape_string($_POST['password']);
$_POST['rememberMe'] = (int)$_POST['rememberMe'];

// Escaping all input data

$row mysql_fetch_assoc(mysql_query("SELECT id,usr FROM tz_members WHERE usr='{$_POST['username']}' AND pass='".md5($_POST['password'])."'"));

if($row['usr']) 
{
// If everything is OK login

//$_SESSION['username']=$row['user'];
$_SESSION['usr']=$row['usr'];
$_SESSION['id'] = $row['id'];
$_SESSION['type'] = $row['type'];
$_SESSION['rememberMe'] = $_POST['rememberMe'];

// Store some data in the session

setcookie('tzRemember',$_POST['rememberMe']);
}
else $err[]='Wrong username and/or password!';
}

if($err)
$_SESSION['msg']['login-err'] = implode('<br />',$err);
// Save the error messages in the session

header("Location: demo.php");
exit;
}
else if(
$_POST['submit']=='Register')
{
// If the Register form has been submitted

$err = array();

if(strlen($_POST['firstname'])>100)
{
$err[]='Your lastname must be less 100 characters!';
}

if(!preg_match('/[^0-9\-\_\.]+/i',$_POST['firstname']))
{
$err[]='Your firstname contains invalid characters!';
}

if(strlen($_POST['lastname'])>100)
{
$err[]='Your lastname must be less 100 characters!';
}

if(!preg_match('/[^0-9\-\_\.]+/i',$_POST['lastname']))
{
$err[]='Your lastname contains invalid characters!';
}

if(strlen($_POST['username'])<|| strlen($_POST['username'])>100)
{
$err[]='Your username must be between 4 and 100 characters!';
}

if(preg_match('/[^a-z0-9\-\_\.]+/i',$_POST['username']))
{
$err[]='Your username contains invalid characters!';
}

if(strlen($_POST['password'])<|| strlen($_POST['password'])>32)
{
$err[]='Your username must be between 6 and 32 characters!';
}

if(preg_match('/[^a-z0-9\-\_\.]+/i',$_POST['password']))
{
$err[]='Your password is weak!';
}

if($_POST['repassword']!=$_POST['password'])
{
$err[]='Your retype password is different than password!';
}

if(!checkEmail($_POST['email']))
{
$err[]='Your email is not valid!';
}

if(!count($err))
{
// If there are no errors

$_POST['email'] = mysql_real_escape_string($_POST['email']);
$_POST['password'] = mysql_real_escape_string($_POST['password']);
$_POST['username'] = mysql_real_escape_string($_POST['username']);
$_POST['firstname'] = mysql_real_escape_string($_POST['firstname']);
$_POST['lastname'] = mysql_real_escape_string($_POST['lastname']);
$_POST['type'] = mysql_real_escape_string($_POST['type']);
// Escape the input data


mysql_query(" INSERT INTO tz_members(firstname,lastname,user,password,email,type,dt)
VALUES('"
.$_POST['firstname']."','".$_POST['lastname']."','".$_POST['username']."','".md5($_POST['password'])."','".$_POST['email']."','".$_POST['type']."',NOW())");


if(mysql_affected_rows($link)==1)
{
send_mail( 'name@yourdomain.com',
$_POST['email'],
'Registration for Demo',
'Your username is: '.$username.'\n Your password is: '.$password);

$_SESSION['msg']['reg-success']='We sent you an email with your login data!';
}
else $err[]='This username is already taken!';
}

if(count($err))
{
$_SESSION['msg']['reg-err'] = implode('<br />',$err);
}

header("Location: demo.php");
exit;
}

$script '';

if(
$_SESSION['msg'])
{
// The script below shows the sliding panel on page load

$script '
<script type="text/javascript">

$(function(){

$("div#panel").show();
$("#toggle a").toggle();
});

</script>'
;

}
?>
#8
Hola! Queria preguntar si alguno de ustedes no tiene un ejemplo sobre cómo hacer una página de perfil de usuarios, o sea que cuando el usuario inicie sesión sea redirigido a un perfil que deba completar.

Alguna sugerencia?


Gracias


den_22
#9
PHP / Contraseña cifrada con MD5
25 Enero 2010, 16:29 PM
Hola nuevamente. Tengo una duda con respecto a la cifrado con md5. Donde deberia poner el $contrasena = md5($contrasena);

Este es el registro.php

<?php
// Configura los datos de tu cuenta
$dbhost='localhost';
$dbusername='username';
$dbuserpass='password';
$dbname='database';
// Conexi&oacute;n a la base de datos
mysql_connect("localhost""username","password" ) or die(mysql_error());
mysql_select_db("database" ) or die(mysql_error());

// Preguntaremos si se han enviado ya las variables necesarias
if (isset($_POST["username"] ) ) {
$username $_POST["username"];
$password $_POST["password"];
$cpassword $_POST["cpassword"];
$email $_POST["email"];
// Hay campos en blanco
if($username==NULL|$password==NULL|$cpassword==NULL|$email==NULL) {
echo 
"Hay Campos Vacios";
}else{
// &iquest;Coinciden las contrase&ntilde;as?
if($password!=$cpassword) {
echo 
"Las Contrase&ntilde;as No Coinciden";
}else{
// Comprobamos si el nombre de usuario o la cuenta de correo ya exist&iacute;an
$checkuser mysql_query("SELECT username FROM users WHERE username='$username'" ) ;
$username_exist mysql_num_rows($checkuser);

$checkemail mysql_query("SELECT email FROM users WHERE email='$email'" ) ;
$email_exist mysql_num_rows($checkemail);

if (
$email_exist>0|$username_exist>0) {
echo 
"EL Nombre de Usuario o la Cuenta de Correo Estan ya en Uso";
}else{
//Todo parece correcto procedemos con la inserccion
$query "INSERT INTO users (username, password, email) VALUES('$username','$password','$email')";
mysql_query($query) or die(mysql_error());
echo 
"El Usuario $username ha Sido Registrado de Manera Satisfactoria. Ahora Puedes Iniciar Session";
}
}
}
}
?>



Y este es el código del entrar.php


<?php
// Configura los datos de tu cuenta
$dbhost='localhost';
$dbusername='username';
$dbuserpass='password';
$dbname='database';

// Conectar a la base de datos
mysql_connect("localhost""username","password" ) or die(mysql_error());
mysql_select_db("database" ) or die(mysql_error());

if (
$_POST['username'] ) {
//Comprobacion del envio del nombre de usuario y password
$username=$_POST['username'];
$password=$_POST['password'];
if (
$password==NULL) {
echo 
"Debes Escribir el Password";
}else{
$query mysql_query("SELECT username,password FROM users WHERE username = '$username'" ) or die(mysql_error());
$data mysql_fetch_array($query);
if(
$data['password'] != $password) {
echo 
"Usuario o Contrase&ntilde;a Incorrecto, sino eres Usuario Puedes Registrarte <a href='registro.html'>Aqu&iacute;</a>";
}else{
$query mysql_query("SELECT username,password FROM users WHERE username = '$username'" ) or die(mysql_error());
$row mysql_fetch_array($query);
$_SESSION["s_username"] = $row['username'];
echo 
"<html><head></head><meta HTTP-EQUIV='Refresh' CONTENT='3; URL=bienvenido-usuario-inicio-session.html'><body>Hola ".$_SESSION['s_username']." Te Vamos a Redireccionar a Tu Cuenta</body></html>";
}
}
}
?>



Nos vemos.
#10
PHP / Ayuda con este código
24 Enero 2010, 17:49 PM
Hola que tal necesito ayuda, con un código de registro en php, el error que me tira es el siguiente: "Warning: mysql_affected_rows() [function.mysql-affected-rows]: A link to the server could not be established in C:\wamp\www\index.php on line 58"

La linea 58 es esta :

if(mysql_affected_rows()==1) {

Ahora el código completo:


<?php
if (isset($_POST['submitted'])) {

    
$errors = array ();
        require_once (
'mysql_connect.php');
}




if (
eregi('^[[:alnum:]\.\'\-]{4,30}$'stripslashes(trim($_POST['username']))) ) {
    
    
$usermysql_real_escape_string($_POST['username']);
    
$query="SELECT username FROM users WHERE username = '$user'";
    
$result=mysql_query($query);
    
$num=mysql_num_rows($result);



    
    if(
$num0) {
        
$errors[] = '<font color="red">The username you have chosen has already been taken, please try again.</font>';
    } else {
        
$username =mysql_real_escape_string($_POST['username']);
    }
  } else {
        
$errors[]='<font color="red">Please provide a valid username between 4 and 30 characters.</font>';
        
        }


if (!
eregi('^[a-zA-Z]+[a-zA-Z0-9_-]*@([a-zA-Z0-9]+){1}(\.[a-zA-Z0-9]+)
{1,2}'
stripslashes(trim($_POST['email'])) )) {
        
$errors[]= '<font color="red">Please provide a valid email adress.</font>';
        } else {
            
$email=mysql_real_escape_string($_POST['email']);
        
        }

if(!empty(
$_POST['password1'])) {
    if(
$_POST['password1'] != $_POST['password2']){
        
$errors[]='<font color="red">The 2 passwords you have entered do not match.</font>';
        } else {
            
$password=$_POST['password1'];
        }
    } else {
        
$errors[]='<font color ="red">Please provide a password.</font>';
    }


if(empty(
$errors)) {
            
$a=md5(uniqid(rand(),true));
        
$query="INSERT INTO users (username, email, password, active) VALUES ('$username','$email', SHA('$password'), '$a')";
        
        
        
$resultmysql_query($query);
        }
        if(
mysql_affected_rows()==1) {
        
                
//Send the E-Mail
                
                
$body="Thank you for registering at the User Registration Site.To activate your account, please click on this link:\n\n";
                
$body.="http://www.whateveraddressyouwantthere.com/activate.php?x=" mysql_insert_id() . "&y=$a";
                
                    
mail($_POST['email'], 'Registration Confirmation'$body'From:contactoweb@writeme.com');
                    
                    
                        
//Show thank message
                
                
echo '<h3>Thank You!</h3>
                
                You have been registered, you have been sent an e-mail to the address you specified before.Please check your e-mails to activate your
account. '
;
                } else {
                
                    echo 
'<font color="red">You could not be registered, please contact us about the problem and we will fix it as soon as we can.</font>';

    }
    

?>

<html>
<head>
</head>
<body>
<h3>Register</h3>
<form action="<?php $_SERVER['PHP_SELF']; ?>" method="post">
<p><input type="text" name="username" value="<?php if (isset($_POST['username'])) echo $_POST['username']; ?>" size="30" maxlenght="30" />
<small>Username</small></p>
<p><input type="password" name="password1" size="30" maxlenght="40" />
<small>Password</small></p>
<p><input type="password" name="password2" size="30" maxlenght="40" />
<small>Confirm Password</small></p>

<p><input type="text" name="email" size="30" maxlenght="30" value="<?php if(isset($_POST['mail'])) { echo $_POST['mail']; } ?>" /> <small> Email Address</small></p>

<p><input type="submit" name="submit" value="Register" /></p>
<input type="hidden" name="submitted" value="TRUE" />

</form>
</body>
</html>




Gracias de antemano.