Foros del Web » Programando para Internet » PHP »

Problemas de novato

Estas en el tema de Problemas de novato en el foro de PHP en Foros del Web. Buenas, yo manejo bien el html y css, pero el php, acabo de empezar con él. Mi problema es que no tengo idea de cómo ...
  #1 (permalink)  
Antiguo 14/07/2013, 16:49
Avatar de The_Code  
Fecha de Ingreso: mayo-2012
Ubicación: Argentina
Mensajes: 98
Antigüedad: 11 años, 11 meses
Puntos: 4
Pregunta Problemas de novato

Buenas, yo manejo bien el html y css, pero el php, acabo de empezar con él.

Mi problema es que no tengo idea de cómo conectar a la base de datos correctamente.
Código de la página de registro:
Código:
<?php
/* Conexión con la base de datos	*/
include_once("conection.php");
$con = mysql_connect($HOSTNAME,$USER,$PASS);
if (!$con){
die(mysql_error());
}
$database = mysql_select_db(“icegames”,$con);
if (!$database){
die(mysql_error());
}
//
$user = $_POST['user'];
$pass = $_POST['pass'];
$mail = $_POST['mail'];
$captcha = $_POST['captcha'];
	// Bad
	// If NO set $user, $pass and $mail
	if(!isset($user, $pass, $mail)){
	echo '<p>Completa todos los campos</p>';
	}
	// Good
	// If captcha is fine and is set user, pass and mail
	if($captcha == "OPP155" AND isset($user, $pass, $mail)){
	// Print the acount info
	echo '<p><strong>Tus datos son</strong></p>';
	echo '<p>Usuario: ', $user, '</p>';
	echo '<p>Contraseña: ', $pass, '</p>';
	echo '<p>Email: ', $mail, '</p>';
	$sql = 'INSERT INTO user (user, pass, mail) VALUES ($user, $pass, $mail)';
	$result = mysql_query($sql);
if (!$result){
echo mysql_error();
exit();
}else {
echo 'Datos insertados correctamente';

}
}
else {
	echo '<p>El captcha es incorrecto | <a href="../register.php">Volver</a></p>';
	}
?>
Conection.php (Archivo que conecta a la BD:

Código:
<?
$enlace =  mysql_connect('127.0.0.1', 'root', '');
if (!$enlace) {
    die('No pudo conectarse: ' . mysql_error());
}
echo 'Conectado satisfactoriamente';
mysql_close($enlace);
?>
Bueno, el error que tira es el siguiente:

Notice: Undefined variable: HOSTNAME in C:\xampp\htdocs\icegames\config\add-reg.php

Notice: Undefined variable: USER in C:\xampp\htdocs\icegames\config\add-reg.php

Notice: Undefined variable: PASS in C:\xampp\htdocs\icegames\config\add-reg.php

Notice: Use of undefined constant “icegames” - assumed '“icegames”' in C:\xampp\htdocs\icegames\config\add-reg.php on line 28
Access denied for user ''@'localhost' to database '“icegames”'

No encuentro nada SIN definir, por eso no entiendo
__________________
Mi portafolio
  #2 (permalink)  
Antiguo 14/07/2013, 17:19
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problemas de novato

Primero deberías aprender lo básico del lenguaje antes de adentrarte a más.

Cita:
No encuentro nada SIN definir, por eso no entiendo
Esto que dices es una falacia, ya que claramente hay variables sin definir, ¿o de pronto te crees que PHP te inventa los errores?

Código PHP:
Ver original
  1. // Aquí claramente haces uso de $HOSTNAME, $USER y $PASS
  2. $con = mysql_connect($HOSTNAME,$USER,$PASS);

¿Pero dónde las estás declarando (definiendo) en primer lugar?

Antes que eso haces un include a conection.php pero tampoco declaras dichas variables ahí, puesto que eso debería ser suficiente.

Piensa además lo siguiente: si tienes un archivo de conexión, ¿por qué duplicas la conexión fuera de dicho archivo y haciendo uso de variables inexistentes?

Que sepas algo de HTML y CSS para nada te faculta para aprender un lenguaje de programación.

De verdad lee un curso básico, aprende lo fundamental, no quieras correr sin siquiera gatear.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 14/07/2013, 18:51
Avatar de The_Code  
Fecha de Ingreso: mayo-2012
Ubicación: Argentina
Mensajes: 98
Antigüedad: 11 años, 11 meses
Puntos: 4
Respuesta: Problemas de novato

huy xD.

Ahora mi código en conection.php es este:

Código:
<?
$conexion = mysql_connect('localhost', 'root','') OR die('Imposible conectar con la base de datos.')
mysql_select_db(“icegames”,$conexion);
?>
y en el php que procesa todo es:

Código:
<?php
/* Conexión con la base de datos	*/
include("conection.php");
//
$user = $_POST['user'];
$pass = $_POST['pass'];
$mail = $_POST['mail'];
$captcha = $_POST['captcha'];
	// Bad
	// If NO set $user, $pass and $mail
	if(!isset($user, $pass, $mail)){
	echo '<p>Completa todos los campos</p>';
	}
	// Good
	// If captcha is fine and is set user, pass and mail
	if($captcha == "OPP155" AND isset($user, $pass, $mail)){
	// Print the account info
	echo '<p><strong>Tus datos son</strong></p>';
	echo '<p>Usuario: <strong>', $user, '</strong></p>';
	echo '<p>Contraseña: <strong>', $pass, '</strong></p>';
	echo '<p>Email: <strong>', $mail, '</strong></p>';
	$sql = 'INSERT INTO user (user, pass, mail) VALUES ($user, $pass, $mail)';
	$result = mysql_query($sql);
if (!$result){
echo mysql_error();
exit();
}else {
echo 'Datos insertados correctamente';
}
}
else {
	echo '<p>El captcha es incorrecto | <a href="http://www.forosdelweb.com/f18/register.php">Volver</a></p>';
	}
?>
Dice: No database selected | Pero si yo desde el conection.php digo que seleccione la base de datos icegames , hay que hacer algo más? Me he visto varios tutos y todos ponen lo mismo, ahora checko la doc de PHP, pero si puedes responderme mejor
__________________
Mi portafolio
  #4 (permalink)  
Antiguo 15/07/2013, 06:55
Avatar de alexisverano  
Fecha de Ingreso: septiembre-2008
Ubicación: La Habana.Cuba
Mensajes: 298
Antigüedad: 15 años, 7 meses
Puntos: 36
Respuesta: Problemas de novato

Ejemplo de conexion con "mysql"

Código PHP:
Ver original
  1. $db_host = "localhost";
  2. $db_usuario = "root";
  3. $db_password = "clave";
  4. $db_base = "libros";
  5. $con = mysql_connect($db_host, $db_usuario, $db_password);
  6. mysql_select_db($db_base, $con);
  7. mysql_query("SET NAMES 'utf8'");
  8. echo mysql_error();

Ejemplo de conexion con "mysqli"

Código PHP:
Ver original
  1. $db_host = "localhost";
  2. $db_usuario = "root";
  3. $db_password = "clave";
  4. $db_base = "libros";
  5. $mysqli = new mysqli($db_host, $db_usuario, $db_password, $db_base);
  6. $mysqli->query("SET NAMES 'utf8'");
  7. echo mysql_error();

Etiquetas: html, mysql, registro, select, sql, variable
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 20:51.