Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: не работает скрипт
 
 автор: ver1   (22.06.2009 в 00:43)   письмо автору
 
 

<?php
session_start();
ini_set('display_errors',1);
error_reporting(E_ALL);
//Поключаем конфиг
include("config.inc.php");

/* Соединяемся с БД*/
$link = mysql_connect($DBSERVER, $DBUSER, $DBPASS)
or die("Не могу подключиться" );
/* Выбираем БД и присваеваем её переменной "$DB"*/
mysql_select_db($DB, $link) or die ('Не могу выбрать БД');
/* Проверяем условие если данные пришли,то присваиваем этим значениям переменные*/
if (isset($_POST['login']))
{
$ilogin = $_POST['login'];
}
else {
echo 'no login!';
}
if (isset($_POST['password']))
{
$upass = $_POST['password'];
}
else{
echo 'no password!';
}
/* Обрабатываем переменные,которые пришли с запросом*/
$ilogin=trim($ilogin);
$ilogin = mysql_real_escape_string($ilogin);
$ilogin=strip_tags(strtolower($ilogin));

if ($ilogin !='' and $upass !='' )
{
/* */

$result = mysql_query("SELECT * FROM users WHERE nick='".$ilogin."' AND pass='".md5($upass)."'",$link);
$t = mysql_num_rows($result);
echo $t;

if ($u = mysql_num_rows($result) == true)
{
/* пропускает этот блог */
$r=mysql_fetch_array($result);
$_SESSION['user'] = $r['nick'];
$_SESSION['password'] = $r['pass'];
$_SESSION['SID'] = md5(crypt($r['nick'],$r['pass']));
echo 'Здравсвуйте '.$r['nick'];
$result=mysql_query("SELECT name FROM users");
$row = mysql_fetch_array($result, MYSQL_ASSOC );
$_SESSION['name']=$row['name'];
}
else {
echo var_dump($result).'<br>'.var_dump($t).'<br>'.var_dump($u).'<br>' ;
/* На экране выдает - resource(4) of type (mysql result) int(0) bool(false) */
}

}

else{
echo 'Введите логин или пароль!';
exit("<br><a href=index.php> Назад </a>");
}

?>


Не понятно что здесь не правильно, подскажите пожалуйста ?

  Ответить  
 
 автор: buldovsky   (22.06.2009 в 00:56)   письмо автору
 
   для: ver1   (22.06.2009 в 00:43)
 

Что именно не работает?
Сделайте, чтобы выводились ошибки и посмотрите...

  Ответить  
 
 автор: ver1   (22.06.2009 в 01:01)   письмо автору
 
   для: buldovsky   (22.06.2009 в 00:56)
 

Не работает mysql_num_rows, т.е выдаёт false a не true....

  Ответить  
 
 автор: buldovsky   (22.06.2009 в 01:10)   письмо автору
 
   для: ver1   (22.06.2009 в 01:01)
 

эта функция возвращает количество рядов результата запроса, а не true и не false
что выводит echo $t?

  Ответить  
 
 автор: ver1   (22.06.2009 в 01:16)   письмо автору
 
   для: buldovsky   (22.06.2009 в 01:10)
 

int(0)

  Ответить  
 
 автор: buldovsky   (22.06.2009 в 01:25)   письмо автору
 
   для: ver1   (22.06.2009 в 01:16)
 

Короче


<?
$result 
mysql_query("SELECT * FROM users WHERE `nick`='$ilogin' AND `pass`= '".md5($upass)."'");

$user mysql_fetch_array($resultMYSQL_ASSOC);

if (empty(
$user)) { 

// нет такого пользователя

} else {

// информация о пользователе в массиве $user

}

?>

  Ответить  
 
 автор: ver1   (22.06.2009 в 01:40)   письмо автору
 
   для: buldovsky   (22.06.2009 в 01:25)
 

$result = mysql_query("SELECT * FROM users WHERE `nick`='$ilogin' AND `pass`= '".md5($upass)."'");

$user = mysql_fetch_array($result, MYSQL_ASSOC);

if (empty($user)) {

// нет такого пользователя
echo 'Нет такого пользователя! ';
} else {

// информация о пользователе в массиве $user
echo 'привет'.$user['nick'];
}

Пишет что нет такого пользователя..... может чего с таблицей в бд?

  Ответить  
 
 автор: ver1   (22.06.2009 в 12:06)   письмо автору
 
   для: buldovsky   (22.06.2009 в 01:25)
 

Нашёл ошибку в БД почему-то пароль резался до 12 символов, поэтому-то при проверки пароли не совпадали и mysql_num_row возвращал false....

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования