Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Передача переменных между страницами вывода контента

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
zlovred
Отправлено: 18 Июля, 2008 - 06:51:10
Post Id



Новичок


Покинул форум
Сообщений всего: 13
Дата рег-ции: Июнь 2008  
Откуда: Красноярск


Помог: 0 раз(а)




Здравствуйте уважаемые.
Ситуация выглядит следующим образом: пользователь заполняет форму, форма передает в скрипт значения переменных $a, $b. Далее скрипт используя эти переменные в запросе к базе выводит из нее информацию постранично. Чтобы значения переменных сохранялись на других страницах(кроме первой) была использована сессия. Проблема заключается в том, что если вновь перейти на страницу с формой и изменить поля а,b. То суже не реагирует на новые значения этих переменных(старые значения сохраняются до выключения браузера). Подскажите пожалуйста, как можно избежать этой ситуации.

Далее приведен код скрипта.
CODE (text):
скопировать код в буфер обмена
  1.  
  2. <?php
  3. session_start();
  4. //Создадим функцию page(), которая обрабатывает данные о запрошенном номере страницы:
  5. function page()
  6. {
  7.     if(empty($_GET["page"])){
  8.         $page = 0;
  9.     } else {
  10. if(!is_numeric($_GET["page"])) die("Неправильный формат номера страницы!");
  11.         $page = $_GET["page"];
  12.     }
  13.         return $page;
  14. }
  15. //Проверяет выбрана ли страница и если в ней присутствуют буквы,
  16. // то выводит сообщение об ошибке. Далее сделаем SQL-запрос:
  17. function sql_query($onpage, $page, $table, $a, $b)
  18. {
  19.     $begin = $page*$onpage; // откуда начинать
  20.         $sql = "SELECT * FROM ".$table." c='".$a."' and
  21.         d>='".$b."' and  LIMIT ".$begin.", ".$onpage;
  22.         $result = mysql_query($sql) or die(mysql_error());
  23.         return $result;
  24.         }
  25. //Функция навигации:
  26. function navigation($onpage, $page, $table)
  27. {
  28.         $return = null;
  29.     $count = mysql_query("SELECT COUNT(*) FROM k") or die(mysql_error());
  30.         $count = mysql_fetch_array($count);
  31.         $count = $count[0];
  32.         $pages = $count/$onpage;
  33.         if($page!==0){
  34.             $prev = "<A HREF=\"?page=".($page-1)."\"><</A>";
  35.         } else {
  36.             $prev = "<";
  37.         }
  38.         if($page<round($pages-1)){
  39.             $next = "<A HREF=\"?page=".($page+1)."\">></A>";
  40.         } else {
  41.             $next = ">";
  42.         }
  43.         for($i=0;$i<$pages;$i++)
  44.         {
  45.             if($i==$page){
  46.                 $return.="[".($i+1)."]";
  47.             } else {
  48.                 $return.="<A HREF=\"?page=".$i."\">[".($i+1)."]</A>";
  49.             }
  50.         }
  51.         return $prev.$return.$next;
  52. $onpage = 10; // записей на страницу
  53. $table = "k"; // из какой таблицы
  54. mysql_connect("localhost", "root", "") or die(mysql_error()); // коннект к БД
  55. mysql_select_db("houses"); // выбор БД
  56. $page = page(); // определяем страницу
  57. $result = sql_query($onpage, $page, $table, $a, $b); // sql - запрос
  58. //вывод инфы
  59. $navigation = navigation($onpage, $page, $table); // определим навигацию
  60. echo $navigation; // выведем ее
  61. $_SESSION['a'] = "$a";
  62. $_SESSION['b'] = "$b";
  63. mysql_close(); // отключение от БД
  64.  

(Отредактировано автором: 18 Июля, 2008 - 06:52:04)

 
 Top
RomAndry Администратор
Отправлено: 18 Июля, 2008 - 09:18:47
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 913
Дата рег-ции: Янв. 2008  


Помог: 6 раз(а)




PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. $_SESSION['a'] = $a;
  4. $_SESSION['b'] = $b;
  5. ?>
  6.  

ну и не вижу я инициализации $a и $b
 
My status
 Top
kamikadze
Отправлено: 18 Июля, 2008 - 09:19:54
Post Id



Склонен к самоубийству


Покинул форум
Сообщений всего: 391
Дата рег-ции: Янв. 2007  


Помог: 0 раз(а)




Очищайте переменную сессии на станице с формой/перед присвоением новых
(Добавление)
RomAndry пишет:
ну и не вижу я инициализации $a и $b

Вероятно register_globals включена, и юзер на это и надеецца)
 
 Top
zlovred
Отправлено: 18 Июля, 2008 - 10:02:07
Post Id



Новичок


Покинул форум
Сообщений всего: 13
Дата рег-ции: Июнь 2008  
Откуда: Красноярск


Помог: 0 раз(а)




Инициализация $a,$b есть, просто я ее не совсем удачно расположил..
Две предпоследние строчки в конце скрипта.


А можно поподробнее насчет
Цитата:
Очищайте переменную сессии на станице с формой/перед присвоением новых

(Отредактировано автором: 18 Июля, 2008 - 10:46:34)

 
 Top
valenok
Отправлено: 18 Июля, 2008 - 12:20:10
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


Помог: 3 раз(а)




Не записывайте параметры поиска, а то я дам кому то ссылку
на, вот он тут третий с верху, и что он увидит ? Фигу.

Параметры поиска в getе пусть передаются


-----
Truly yours, Sasha.
 
My status
 Top
scuter
Отправлено: 18 Июля, 2008 - 19:44:37
Post Id



Посетитель


Покинул форум
Сообщений всего: 282
Дата рег-ции: Янв. 2008  


Помог: 0 раз(а)




гггг Радость Радость
ты сначало проверь пришли ли значения из формы,
если пришли заменяй,
а потом выполняй вывод для страници.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB