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 :: Ajax POST запрос.

 PHP.SU

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


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

> Без описания
Pyroman
Отправлено: 28 Мая, 2012 - 16:12:02
Post Id


Новичок


Покинул форум
Сообщений всего: 14
Дата рег-ции: Май 2012  


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




Здравствуйте. Возможно ли сделать выполнение скрипта при POST запросе через AJAX прямо в данном файле? Есть файл index.php и в нём следующий AJAX скрипт:
CODE (javascript):
скопировать код в буфер обмена
  1. <script type="text/javascript" src="http://mysite.ru/jquery-1.7.2.js"></script>
  2. <script type="text/javascript">
  3.                 function buy1(that) {
  4.         var count = $(that).closest('form').find('.count').val();
  5.         var buy4 = $(that).val();
  6.        
  7.         $.ajax({
  8.                 type: "POST",
  9.                 data: "count="+count+"&buy0="+buy4+"&hbdgvffvetvfgdvgfvdgvfgdvghfvdghvfghdv=fbhabfhbshfbhsbfh",
  10.                 url: 'http://mysite.ru/engine/modules/shop/index.php',
  11.                 success: function(data) {
  12.                         alert(data);
  13.                 }
  14.         });
  15. }
  16. </script>

PHP:
скопировать код в буфер обмена
  1. if(isset($_POST['buy0']))
  2. {
  3. $idtovara = $_POST['buy0'];
  4. $iprice = mysql_query("SELECT price FROM donate_shop WHERE item_id='$idtovara'");
  5. $nazvanie = mysql_query("SELECT name FROM donate_shop WHERE item_id='$idtovara'");
  6. $icount = mysql_query("SELECT stack FROM donate_shop WHERE item_id='$idtovara'");
  7. $koplate = $iprice*$_POST['count'];
  8. $kolichestvo = $_POST['count']*$icount;
  9. $username10 = $member_id['name'];
  10. $sql_price = mysql_query("SELECT price FROM donate_shop WHERE item_id='$idtovara'");
  11. $price_result = mysql_result($sql_price, 0);
  12. $sql_num = mysql_query("SELECT stack FROM donate_shop WHERE item_id='$idtovara'");
  13. $query_num = mysql_result($sql_num, 0);
  14. $count = $_POST['count'];
  15. if(is_numeric($count)){
  16. if($count == (int)$count){
  17. if(!$count == '0'){
  18. if($username10 == ''){
  19. echo "Сначала авторизируйтесь!";
  20. }else{
  21.         $sql = mysql_query("SELECT cash FROM $db_realmon WHERE name='$username10' $member_id");
  22.         $query = mysql_result($sql,0);
  23. if($query < $koplate){
  24. echo "У вас недостаточно средств, пополните счет через личный кабинет.";}
  25.         else{
  26.   mysql_query("UPDATE `realmoney` SET `cash` = `cash` - ".str_replace(',', '.', $koplate)." WHERE `name` = '".$username10."'")or die(mysql_error());
  27.   mysql_query("INSERT INTO goods (id, nickname, item_id, item_amount) VALUES (NULL, '$username10', '$idtovara', '$kolichestvo')")or die(mysql_error());
  28.         $logtext = "$date : $username10 купил $nazvanie в количестве $kolichestvo";
  29.         echo "Вы успешно купили $kolichestvo $nazvanie";
  30.         $fp = fopen('shop.txt', 'a');
  31.         fwrite($fp, $logtext);
  32.         fwrite($fp, "\n");
  33.         fclose($fp);
  34.         }}}else{
  35.         echo "Введите правильное число";
  36.         }
  37.         }else{
  38.         echo "Введите целое число в 'Количество'";
  39.         }
  40.         }else{
  41.         echo "Вы ввели неправильное количество";
  42.         }
  43. }

Раньше, когда мне надо было выполнить скрипт непосредственно в файле после POST запроса я использовал "if(isset($_POST['abc']))", всё было отлично, но как я понял с AJAX запросом это не прокатывает, т.к. мне возвращается содержимое всего файла index.php... Как это можно реализовать? Спасибо.

(Отредактировано автором: 28 Мая, 2012 - 16:17:12)

 
 Top
armancho7777777 Супермодератор
Отправлено: 28 Мая, 2012 - 17:49:20
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


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




А можно узнать, - почему вы хотите сделать именно так ?)
 
 Top
Alho
Отправлено: 28 Мая, 2012 - 17:58:59
Post Id



Посетитель


Покинул форум
Сообщений всего: 322
Дата рег-ции: Апр. 2012  


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




Пожелания написать за вас я не услышал, так что поясню.

Как правило обработчиком выступает другой файл. Ничего не мешает вынести весь рабочий код в другой файл.

Если любите извращения, то можно и в этом же файле, но вот возвращать нужно не весь файл. jquery поддерживает интересную вещь - он может загрузить содержимое определенного блока, в котором вы и будете выводить ответ сервера.
 
 Top
Pyroman
Отправлено: 28 Мая, 2012 - 18:12:08
Post Id


Новичок


Покинул форум
Сообщений всего: 14
Дата рег-ции: Май 2012  


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




Тогда мне надо всё равно использовать if(isset) и в нём include('file.php');. Но опять же та же проблема. У моего движка особенность такая, что надо именно использовать include в главном файле, чтобы я мог получить имя пользователя посредством $member_id['name'];.
Мне обязательно надо использовать if(isset), но вот как решить проблему, что при ajax post запросе он просто выводит в alert`е код index.php...
(Добавление)
То есть сделать так:
PHP:
скопировать код в буфер обмена
  1.  
  2.     if(isset($_POST['buy0']))
  3.     {
  4. include('pokupka.php');
  5.     }
  6.  


Но как я уже сказал, просто при нажатии на кнопку в alert`е выводит сам php-код index.php...

(Отредактировано автором: 28 Мая, 2012 - 18:23:16)

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


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB