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
Форумы портала PHP.SU :: Версия для печати :: Помогите с корзиной для интернет магазина
Форумы портала PHP.SU » PHP » Программирование на PHP » Помогите с корзиной для интернет магазина

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

1. dermff - 22 Января, 2013 - 00:54:15 - перейти к сообщению
Доброй ночи! Есть тут щас кто не спит?) Помогите пожалуйста с написанием корзины для интернет магазина.. Есть форма ввода колличества товара и ссылка купить товар. как сделать проверку если id товара уже добавлен в сессию, то повторно не добавлялся?

И суть в том, что необходимо сделать так, чтобы можно было несколько разных товаров с разными id хранить в корзине.

Сам код:

PHP:
скопировать код в буфер обмена
  1. $id = intval($_GET['id']); //id товара
  2. $count = $_POST['count']; //колличество товара
  3.  
  4. if (!isset($_SESSION['basket'])) {
  5. $_SESSION['basket'] = array();
  6. }
  7.  
  8.  
  9. if(isset($_GET['id']) && mysql_result(mysql_query("SELECT COUNT(*) FROM `tovar` WHERE `id`='".intval($_GET['id'])."'"), 0) == 1) {
  10. $_SESSION['basket'][]=$_GET['id'];
  11. }
  12.  
  13. //$sql = "SELECT * FROM `tovar` WHERE `id` = IN (".implode(',', $_SESSION['basket']).")";
  14. $sql = "SELECT * FROM `tovar` WHERE `id` IN (".$_SESSION['basket'][0].")";
  15.  
  16. $result=mysql_query($sql);
  17.  
  18. while($res = mysql_fetch_assoc($result))
  19. {
  20. echo "</br></br><h1>".$res['price']."</h1>";
  21. }
2. dermff - 22 Января, 2013 - 18:09:52 - перейти к сообщению
Сделал проверку чтобы если id товара уже добавлен в сессию, то повторно не добавлялся, не работает почему-то:

PHP:
скопировать код в буфер обмена
  1. $id = intval($_GET['id']); //id товара
  2. $count = $_POST['count']; //колличество товара
  3. if (!isset($_SESSION['basket'])) {
  4. $_SESSION['basket'] = array();
  5. }
  6.  
  7.  
  8. if(isset($_GET['id']) && mysql_result(mysql_query("SELECT COUNT(*) FROM `tovar` WHERE `id`='".intval($_GET['id'])."'"), 0) == 1) {
  9. $_SESSION['basket'] = array();
  10. if (!in_array("$id", $_SESSION['basket'])) {
  11.  
  12. $_SESSION['basket'][]=$_GET['id'];
  13. }
  14. }
  15.  
  16. //$sql = "SELECT * FROM `tovar` WHERE `id` = IN (".implode(',', $_SESSION['basket']).")";
  17. $sql = "SELECT * FROM `tovar` WHERE `id` IN (".$_SESSION['basket'][0].")";
  18.  
  19. $result=mysql_query($sql);
  20.  
  21. while($res = mysql_fetch_assoc($result))
  22. {
  23. echo "</br></br><h1>".$res['price']."</h1>";
  24. }
3. spsu - 22 Января, 2013 - 18:23:17 - перейти к сообщению
in_array надо юзать с оператором равенства, и проверки типа, in_array === false
Если товар будет в 0-ом эл-те массива, то он добавиться...
4. dermff - 22 Января, 2013 - 18:33:06 - перейти к сообщению
помоги плиз это осуществить
5. spsu - 22 Января, 2013 - 18:37:12 - перейти к сообщению
PHP:
скопировать код в буфер обмена
  1. if (in_array("$id", $_SESSION['basket']) === false) {
  2.    $_SESSION['basket'][]=$_GET['id'];
  3. }
  4.  
6. dermff - 22 Января, 2013 - 18:42:22 - перейти к сообщению
спасибо, теперь работает.. А как сделать чтобы возле id товара добавлялось в сессию его колличество которое передается через post в переменной $count ?
7. dermff - 22 Января, 2013 - 21:58:28 - перейти к сообщению
я так понял это нужно применить ассоциативный массив? Помогите пожалуйста это сделать
8. caballero - 22 Января, 2013 - 23:44:33 - перейти к сообщению
Интересно, как можно писать интернет магазин не имея понятия о такой элементарной вещи как работа с массивами.

Делается массив - id товара, количество, цена или что там еще - это запись строки в корзине.
этот массив, и другие ему подобные если в корзине еще строки, запихивается в массив который живет в сессии.
9. dermff - 23 Января, 2013 - 08:31:29 - перейти к сообщению
Проблема решена, всем спасибо!

 

Powered by ExBB FM 1.0 RC1