Jump to content

[SOLVED] Login Script


cfgcjm

Recommended Posts

Working on this login script and it's running but even if i put a valid username and passwrod in it sends me to the rejection page. Anyone see any issues?

 

<?php
/* Login Script */
require ('mysql.php');
session_start();

if (isset ($_POST['submit'])) { // Check to see if the form has been submitted
$username = $_POST['username'];
$password = md5 ($_POST['password']); // we MD5 encrypted the password at registration, 
									  // so we must do this on the login as well

// See if the user exists
$sql = "SELECT * FROM users WHERE username='$username' AND password='$password'";
if ($r = mysql_query ($sql)) {
	$row = mysql_fetch_array ($r);
	$num = mysql_num_rows ($r);

	if ($num > 0) { // if there is a row with that username/password, the user exists
		// Now we can assign some SESSIONS, so we can verify on later pages that the user is "logged in"
		$_SESSION['users_id'] = $row['users_id'];
		$_SESSION['username'] = $row['username'];
		$_SESSION['loggedin'] = TRUE; // This is where we will check to see if the user is logged in
		header("Location:home.php");
		exit;

	} else {
		// User does not exist
		header("location:reject.php");
		exit;
	}
} else {
	// The query failed
	print 'ERROR : Connection Not Established'; // print the MySQL error
	exit;
}
}
?>

Link to comment
Share on other sites

try this:

$sql = "SELECT * FROM users WHERE username='$username' AND password='$password'";
if ($r = mysql_query ($sql)) {
	$row = mysql_fetch_array ($r);
	$num = mysql_num_rows ($r);

	if ($num > 0) { // if there is a row with that username/password, the user exists
		// Now we can assign some SESSIONS, so we can verify on later pages that the user is "logged in"
		$_SESSION['users_id'] = $row['users_id'];
		$_SESSION['username'] = $row['username'];
		$_SESSION['loggedin'] = TRUE; // This is where we will check to see if the user is logged in
		header("Location:home.php");
		exit;

	} else {
die(mysql_error());
	}

Link to comment
Share on other sites

i adapted it into my code like this:

<?php
require ('mysql.php');
session_start();
if (isset ($_POST['submit'])) { // Check to see if the form has been submitted
$username = $_POST['username'];
$password = md5 ($_POST['password']); // we MD5 encrypted the password at registration, 
									  // so we must do this on the login as well
$sql = "SELECT * FROM users WHERE username='$username' AND password='$password'";
if ($r = mysql_query ($sql)) {
	$row = mysql_fetch_array ($r);
	$num = mysql_num_rows ($r);

	if ($num > 0) { // if there is a row with that username/password, the user exists
		// Now we can assign some SESSIONS, so we can verify on later pages that the user is "logged in"
		$_SESSION['users_id'] = $row['users_id'];
		$_SESSION['username'] = $row['username'];
		$_SESSION['loggedin'] = TRUE; // This is where we will check to see if the user is logged in
		header("Location:home.php");
		exit;

	}}} else {
die(mysql_error());
}		
?>

and got nothing but a blank white screen

 

Link to comment
Share on other sites

scratch that i dont think im doign that right anyway. haha

 

try doing a sql query to get the data that relates to the username

<?php 
$query="SELECT * FROM users WHERE username = '$username' LIMIT 1"; 
$result=mysql_query($query); 
while($array=mysql_fetch_assoc($result)){
$dbpassword = $array['password']
}
if($password == $dbpassword){
continue
} else {
bla bla bla

?>

Link to comment
Share on other sites

i had to change your code around cause it was giving me a whole load of syntax errors but i changed it to this and got a yes returned:

<?php 
require ('mysql.php');
$query="SELECT * FROM users WHERE username = '$username' LIMIT 1"; 
$result=mysql_query($query); 
while($array=mysql_fetch_assoc($result)){
$dbpassword = $array['password'];
}
if($password == $dbpassword){
print'yes';} else {
print'bla bla bla';
}
?>

Link to comment
Share on other sites

Try like this:

 

<?php 
require ('mysql.php');
$query="SELECT * FROM users WHERE username = '$username' LIMIT 1"; 
$result=mysql_query($query);
if(mysql_num_rows($result)>0){
$array=mysql_fetch_object($result);
$dbpassword = $array['password'];

if($password == $dbpassword){
echo 'yes';} else {
echo 'bla bla bla';
}
}
?>

Link to comment
Share on other sites

First of all fry to echo

$sql = "SELECT * FROM users WHERE username='$username' AND password='$password'";

and see what query you get and is it working on the mysql also.

 

And also check with the register_globals directive in the php.ini file, if it is on then it might be possible that your $password variable is pointing to the password entered by the user (not the one which you encrypted by md5).

 

 

Link to comment
Share on other sites

I'm with sstangle73 on AIM so it's changing but right now it's

 

<?php
include("mysql.php");
session_start();
error_reporting(E_ALL);
if(isset($_POST['submit'])){ 
  
$username = $_POST['username'];
$userpass = md5($_POST['password']); 
  
$query="SELECT * FROM users WHERE username = '$userpass' LIMIT 1"; 
$result=mysql_query($query) or die(mysql_error()); 
if(mysql_num_rows($result)>0){
$array=mysql_fetch_array($result);
$dbpassword = $array[password];
}
if($userpass == $dbpassword){
echo "Pass";
} else {
echo "Fail" . $password . "," . $dbpassword . "," . $userpass . "," . $username; 
  
}
} else {
echo "You Must Fill Out The Form";
}
?>

Link to comment
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.