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

Форум PHP

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

 

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

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

тема: Определение посетителей OnLine
 
 автор: magic   (08.02.2009 в 01:11)   письмо автору
 
 

Помогите исправить код. Чесно признаюсь код взял из книги РНР5 на примерах, да простят меня авторы. Речь идет о опрделении посетителей он-лайн. Я его немного укоротил и видемо что то напортачил, он мне постояно выдает цифру 1, хотя реально на сайт в это время заходят несколько посетителей, это точно. Вот этот код:
это код в самом начале страницы.

<?php
session_start
();
$id_session=session_id();
?>

код в самой странице.

<?php
      
include "incl/connect.php";
                
$query="select * from session where id_session='$id_session'";
                
$ses=mysql_query($query);
       if(
mysql_num_rows($ses)>0)
                {
                     
$query="update session set putdate=now(), where id_session='$id_session'";
                       
mysql_query($query);
                }
                else
               {
                     
$query="insert into session values('$id_session', now())";
                     
mysql_query($query);
               }
               
$query="delete from session where putdate<now() - interval '1' minute";
               
mysql_query($query);
            
               
$query="select count(*) from session where id_session";
               
$athmysql_query($query);
               echo 
mysql_num_fields($ath);
               
?>


Во-первых: при выводе индентификатора сессии в браузери и в локальной БД (при проверке) выводится нормальный идентификатор (ну там цифры буквы все как положено), но при записе в БД на реальном хосте, записуются числа типа 127, 0 и т.д. как я понимаю это не то.
в чем загвостка.
Во-вторых: как я уже упоменал выше постоянно выводится цифра один, как на локальном так и на реальном хосте. Написано вроде все правильно. Ты кните мне пальцом пожалуйста, где чертова ошибка. Заранее Всем откликнувшимся Спасибо.

  Ответить  
 
 автор: cheops   (08.02.2009 в 03:59)   письмо автору
 
   для: magic   (08.02.2009 в 01:11)
 

Таблица session какую структуру имеет (посмотреть можно при помощи оператора SHOW CREATE TABLE)?

  Ответить  
 
 автор: magic   (08.02.2009 в 18:44)   письмо автору
 
   для: cheops   (08.02.2009 в 03:59)
 

CREATE TABLE `session` (`id_session` tinytext NOT NULL, `putdate` datetime NOT NULL default '0000-00-00 00:00:00')
ENGINE=MyISAM DEFAULT CHARSET=latin1 

И еще один момент, время при новой сессии то же не всегда обновляется. Т.е. как я понимаю при всяческих переходах по ссылкам или еще как то должен срабатывать UPDATE а оно (время) почему то тоже не всегда обновляется. Допустим зашел в 10:15 потом время это не изменяется, хотя как я понимаю должно обновляться

  Ответить  
 
 автор: magic   (09.02.2009 в 12:37)   письмо автору
 
   для: magic   (08.02.2009 в 01:11)
 

Ну помогите кто нибуть.

  Ответить  
 
 автор: Trianon   (09.02.2009 в 12:49)   письмо автору
 
   для: magic   (08.02.2009 в 01:11)
 

впечатление такое, что переменная $id_session до второго фрагмента кода просто не доживает.

Отдельно, вызывает оторопь выбранный тип поля id_session, ну и отсутствие на нем индекса... уже как следствие.

  Ответить  
 
 автор: magic   (09.02.2009 в 12:57)   письмо автору
 
   для: Trianon   (09.02.2009 в 12:49)
 

Последнее предложение, извеняюсь, не понял. А переменая $id_session вроде выводится в конце второго кода, я там помещаю echo $id_session и все есть, что то вроде такого 48575729f508160f2aee1e8759123b68. Да еще на локальном сервере, в БД записуется все нормально, но всеровно выводит постояно цифру один.

  Ответить  
 
 автор: Trianon   (09.02.2009 в 13:08)   письмо автору
 
   для: magic   (09.02.2009 в 12:57)
 

>Последнее предложение, извеняюсь, не понял.
в tinytext хранят текст.
Текстовый ключ хранят в char(32)
а еще неплохо индекс создать на этом поле.

>А переменая $id_session вроде выводится в конце второго кода, я там помещаю echo $id_session и все есть, что то вроде такого 48575729f508160f2aee1e8759123b68.

Да еще на локальном сервере, в БД записуется все нормально, но всеровно выводит постояно цифру один.
запрос у Вас select count(*) from session where id_session возвращает одно число: одно поле в одной строке.

echo mysql_num_fields($ath);
выводит число полей результата. то есть 1.

Сам запрос тоже валит с ног.
select count(*) from session where id_session - сообщить число записей в таблице, где поле id_session отлично от нуля.
Наверное, вы всё же что-то не то хотели вывести.

  Ответить  
 
 автор: magic   (09.02.2009 в 13:59)   письмо автору
 
   для: Trianon   (09.02.2009 в 13:08)
 

Я все сделал как в книге, едиственное переделал низ кода. Мне надо просто количество посетителей в данный момент, а там виводилось по Аноним или нет и все такое. Мне это не надо вот и подкоректировал не много. Исправил на char(32) все нормально. А как теперь вывести кол. посетителей т.е. как запрос сделать в БД. Я так понимаю сумму строк надо вывести. все кто больше времени удаляются из списка, правильно. Оставшиеся и будут колвом посетителей он лайн?

  Ответить  
 
 автор: Trianon   (09.02.2009 в 14:15)   письмо автору
 
   для: magic   (09.02.2009 в 13:59)
 

SELECT COUNT(*) AS с FROM 
  (SELECT id_session, COUNT(*) FROM session GROUP BY id_session) AS t 

echo mysql_result(mysql_quey($sql), 0, 0);

  Ответить  
 
 автор: magic   (10.02.2009 в 13:57)   письмо автору
 
   для: Trianon   (09.02.2009 в 14:15)
 

Спасибо всем кто откликнулся,на небольшую, но все же проблему. Пока вроде все работает

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

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