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]   

> Без описания
Zuldek
Отправлено: 26 Января, 2011 - 10:08:56
Post Id


Постоянный участник


Покинул форум
Сообщений всего: 2122
Дата рег-ции: Июнь 2010  


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




Есть, к примеру, 2 таблицы 1 - заказы, 2 - сами коды. Все поля, — числовые индексы. (указаны примерные имена).
CODE (htmlphp):
скопировать код в буфер обмена
  1. orders
  2. orders_id | orders_shid | orders_usid | orders_amount | orders_status
  3. orders_id - праймери, инкремент.
  4. orders_shid - идентификатор группы к которой относятся продаваемые купоны
  5. orders_usid - id пользователя
  6. orders_amount  - кол-во заказанных кодов
  7. orders_status - статус заказа. Оплачен — 1, не оплачен — 0;
  8.  
  9. coupons
  10. coupon_id | coupon_shid | coupon_num | coupon_owner | coupon_status
  11. coupon_id - праймери, инкремент.
  12. coupon_shid - группа к которой относится код (=orders_shid)
  13. coupon_num - сам код
  14. coupon_owner - id юзера, заказавшего купон (=orders_usid)
  15. coupon_status - 0/1 используется для блокировки купонов в случае поступления на них заказа.

Страница показа кодов делает такие проверки -
1. Смотрит авторизованный ли юзер зашёл.
2. Если авторизованный, сравниваем orders_id с сессией, если юзер тот, чей заказ, то идём дальше.
3. Проверяем на наличие и фильтруем все пришедшее в $_POST, если прошли проверку, - записываем их в переменные
4.
CODE (htmlphp):
скопировать код в буфер обмена
  1. $q = "SELECT * FROM `coupons` WHERE `coupons_status`='1' AND `coupons_owner`='". (int)$orders_usid."' AND `coupons_shid`='". (int)$orders_shid."' LIMIT '" (int)$orders_amount."';";
  2. $reselt = @mysql_query($q);
  3. if($reselt && mysql_num_rows($reselt)==(int)$orders_amount) {
  4. echo "показываем код";
  5. }
  6. else echo "ошибка";

Достаточно-ли безопасен такой подход к показу купленных скрытых данных? Поле orders_id никак не связано с таблицей coupons, может есть смысл использовать его вместо полей coupon_status и coupon_owner?

P.S. Прошу прощение за ошибки в название темы. Никто не отвечает, потому подсократил пояснения.

(Отредактировано автором: 26 Января, 2011 - 11:23:53)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB