Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
14 / 0 / 0
Регистрация: 12.02.2013
Сообщений: 15

Повторная отправка данных

04.05.2015, 01:53. Показов 1274. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
При отправке данных методом POST скрипт ...
PHP
1
2
3
4
5
6
7
8
if (!headers_sent($filename, $linenum)) {
header('Location: $url');
$sent_info=1;
exit;
} else {
  echo "Заголовки уже были отправлены в $filename в строке $linenum\n";
   die('Повторная отправка данных');
}
... идет по пути else и не обнуляет POST, тем самым позволяя пользователю обновлять страницу сколько угодно раз занося в БД одни и те же данные.
$linenum ссылается на PHP код, в котором идет присвоение переменным значений из формы
PHP
1
2
3
$id_client = intval(str_replace(",",".",$_POST['drop_client']));
$razmer_dl = floatval(str_replace(",",".",$_POST['razmer_dl']));
$razmer_sh = floatval(str_replace(",",".",$_POST['razmer_sh']));
За последние три часа в попытках найти и исправить код был обнаружен конфликт между функциями и/или переменными указанными выше (всё это было обнаружено в результате удаления большей части кода)
PHP
1
2
error_reporting(E_ALL);
ini_set('display_errors', 1);
Notice: Undefined index: drop_client in /var/www/page/zakaz1.php on line 94
учитывая что drop_client это часть формы, я просто не знаю как ее определить (возможно в этом и есть суть проблемы, мне опыта не хватает чтоб это утверждать и найти решение).
Вчера код работал нормально, единственное что я сделал за сегодня это (пересохранил вчерашнюю версию файла ) добавил форму в таблицу.

А это весь проблемный код (та часть, которая всё еще вызывает ошибку):
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?php
 
error_reporting(E_ALL);
ini_set('display_errors', 1);
  ?>
<body>
  <b> Сформировать новый заказ</b>
<br>    
<br>
<form action="" method="post" name="zakaz">
<table>
    <tr>
        <td colspan="3">
<label for="name_client">Наименование:</label>
<?php
function name_cl()
  {
    $query="SELECT `name_client`,`id_client`
            FROM `client`
            ORDER BY `client`.`name_client` ASC";
    $query_res=mysql_query($query);
    $name_cl = array();
    while($row = mysql_fetch_assoc($query_res))
      {
          $name_cl[] = $row;
      }
    return $name_cl;
  }
$name_cl = name_cl();
echo "<select name='drop_client'>";
foreach($name_cl as $item)
    { 
      echo "<option value=' ".$item['id_client']." '>".$item['name_client']."</option>";
    } 
echo "</select>";
?></td>
    </tr>
    <tr>
        <td colspan="3">
<label for="opisanie">Описание:</label>
<input type="text" name="opisanie" size="50">
        </td>
    </tr>
    <tr>
        <td>
<label for="razmer">Размер (длина/ширина):</label>
<input type="text" name="razmer_dl" size="3"> / 
        <td><input type="text" name="razmer_sh" size="3"></td>
        <td><label for="kolvo">Количество:</label>
<input type="text" name="kolvo" size="3"> </td>
    </tr>
    <tr>
        <td colspan="2"><label for="name_mat">Материал:</label>
<?php
function name_mat()
  {
    $query="SELECT group_mat.id_group, group_mat.name_group, materials.name_mat, materials.id_groupmat, materials.id_mat
            FROM group_mat, materials
            WHERE group_mat.id_group=materials.id_groupmat
            ORDER BY group_mat.name_group ASC";
    $query_res=mysql_query($query);
    $name_mat = array();
    while($row = mysql_fetch_assoc($query_res))
      {
          $name_mat[] = $row;
      }
    return $name_mat;
  }
$name_mat = name_mat();
echo "<select name='drop_mat'>";
foreach($name_mat as $item_m)
    { 
      echo "<option value=' ".$item_m['id_mat']." '>".$item_m['name_group']." ".$item_m['name_mat']."</option>";
    } 
echo "</select>";
?></td>
        <td><label for="luvers">Люверсы (шт):</label>
<input type="text" name="luvers" size="3"></td>
    </tr>
    <tr>
        <td colspan="3"><label for="opisanie">Номер выставленного счета:</label>
<input type="text" name="num_schet" size="10"></td>
    </tr>
</table>
<input id="submit" type="submit" value="Внести данные"><br/>
</form>
<br>
 
</body>
 
  <?php
 
 
$id_client = intval(str_replace(",",".",$_POST['drop_client']));
$razmer_dl = floatval(str_replace(",",".",$_POST['razmer_dl']));
$razmer_sh = floatval(str_replace(",",".",$_POST['razmer_sh']));
$kolvo = intval(str_replace(",",".",$_POST['kolvo']));
$id_mat = intval(str_replace(",",".",$_POST['drop_mat']));
$luvers = intval(str_replace(",",".",$_POST['luvers']));
$opisanie= mysql_real_escape_string(htmlspecialchars(strip_tags(trim($_POST['opisanie']))));
$num_schet= mysql_real_escape_string(htmlspecialchars(strip_tags(trim($_POST['num_schet']))));
 
if (!headers_sent($filename, $linenum)) {
header('Location: $url');
 
exit;
} else {
  echo "Звголовки уже были отправлены в $filename в строке $linenum\n";
   die('Повторная отправка данных');
}
 
?>
Добавлено через 8 минут
позабыл указать самое важное, данный код уведомляет об ошибке
Заголовки уже были отправлены в /var/www/page/zakaz1.php в строке 96 Повторная отправка данных
сразу, без нажатия на кнопку.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.05.2015, 01:53
Ответы с готовыми решениями:

Повторная отправка данных
Здравствуйте. Использую php для того, чтобы добавить данные в БД. Но получается так, что данные дублируются. Не подскажете, из-за чего...

Повторная отправка данных
Суть вопроса: Я создал простую форму регистрации. Данные успешно вносят в БД, но после обновления страницы данные повторно отправляются....

Повторная отправка данных формы при обновлении страницы
Я так понимаю, что это стандартный механизм браузера? Только у меня с ним нарушается логика работы скрипта. Следует ли это считать...

4
31 / 45 / 21
Регистрация: 09.10.2012
Сообщений: 825
04.05.2015, 01:57
Лучший ответ Сообщение было отмечено cubiculus как решение

Решение

cubiculus, первое что напрашивается на мысль
PHP
1
2
3
if(isset($_POST['drop_client'])) {
$id_client = intval(str_replace(",",".",$_POST['drop_client']));
}
1
14 / 0 / 0
Регистрация: 12.02.2013
Сообщений: 15
04.05.2015, 02:17  [ТС]
ошибки, связанные с неопределенными переменными ушли, но основная (с повторной отправкой данных) осталась и ссылается на строку 100, ту с которой начинается второй PHP блок

исправленный код ниже:
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
<?php
 
  error_reporting(E_ALL);
ini_set('display_errors', 1);
  ?>
<body>
  <b> Сформировать новый заказ</b>
<br>  
<br>
<form action="" method="post" name="zakaz">
<table>
    <tr>
        <td colspan="3">
<label for="name_client">Наименование:</label>
<?php
function name_cl()
  {
    $query="SELECT `name_client`,`id_client`
            FROM `client`
            ORDER BY `client`.`name_client` ASC";
    $query_res=mysql_query($query);
    $name_cl = array();
    while($row = mysql_fetch_assoc($query_res))
      {
          $name_cl[] = $row;
      }
    return $name_cl;
  }
$name_cl = name_cl();
echo "<select name='drop_client'>";
foreach($name_cl as $item)
    { 
      echo "<option value=' ".$item['id_client']." '>".$item['name_client']."</option>";
    } 
echo "</select>";
?></td>
    </tr>
    <tr>
        <td colspan="3">
<label for="opisanie">Описание:</label>
<input type="text" name="opisanie" size="50">
        </td>
    </tr>
    <tr>
        <td>
<label for="razmer">Размер (длина/ширина):</label>
<input type="text" name="razmer_dl" size="3"> / 
        <td><input type="text" name="razmer_sh" size="3"></td>
        <td><label for="kolvo">Количество:</label>
<input type="text" name="kolvo" size="3"> </td>
    </tr>
    <tr>
        <td colspan="2"><label for="name_mat">Материал:</label>
<?php
function name_mat()
  {
    $query="SELECT group_mat.id_group, group_mat.name_group, materials.name_mat, materials.id_groupmat, materials.id_mat
            FROM group_mat, materials
            WHERE group_mat.id_group=materials.id_groupmat
            ORDER BY group_mat.name_group ASC";
    $query_res=mysql_query($query);
    $name_mat = array();
    while($row = mysql_fetch_assoc($query_res))
      {
          $name_mat[] = $row;
      }
    return $name_mat;
  }
$name_mat = name_mat();
echo "<select name='drop_mat'>";
foreach($name_mat as $item_m)
    { 
      echo "<option value=' ".$item_m['id_mat']." '>".$item_m['name_group']." ".$item_m['name_mat']."</option>";
    } 
echo "</select>";
?></td>
        <td><label for="luvers">Люверсы (шт):</label>
<input type="text" name="luvers" size="3"></td>
    </tr>
    <tr>
        <td colspan="3"><label for="opisanie">Номер выставленного счета:</label>
<input type="text" name="num_schet" size="10"></td>
    </tr>
</table>
<input id="submit" type="submit" value="Внести данные"><br/>
</form>
<br>
 
<br>  
<b>Отредактировать заказ:</b>
<form action="index.php?page=redactor_zakaz" method="post" name="redactor_zakaz">
<label for="num_zakaz">Номер заказа: </label>
<input type="text" name="num_zakaz" size="5"><br/>
 
<br/>
<input id="submit" type="submit" value="Отправить"><br/>
</form>
</body>
 
<?php
if(isset($_POST['drop_client'])) {
$id_client = intval(str_replace(",",".",$_POST['drop_client']));
}
if(isset($_POST['razmer_dl'])) {
$razmer_dl = intval(str_replace(",",".",$_POST['razmer_dl']));
}
if(isset($_POST['razmer_sh'])) {
$razmer_sh = intval(str_replace(",",".",$_POST['razmer_sh']));
}
if(isset($_POST['kolvo'])) {
$kolvo = intval(str_replace(",",".",$_POST['kolvo']));
}
if(isset($_POST['drop_mat'])) {
$kolvo = intval(str_replace(",",".",$_POST['drop_mat']));
}
if(isset($_POST['kolvo'])) {
$id_mat = intval(str_replace(",",".",$_POST['kolvo']));
}
if(isset($_POST['luvers'])) {
$luvers = intval(str_replace(",",".",$_POST['luvers']));
}
if(isset($_POST['opisanie'])) {
$opisanie = mysql_real_escape_string(htmlspecialchars(strip_tags(trim($_POST['opisanie']))));
}
if(isset($_POST['num_schet'])) {
$num_schet = mysql_real_escape_string(htmlspecialchars(strip_tags(trim($_POST['num_schet']))));
}
 
 
if (!headers_sent($filename, $linenum)) {
header('Location: $url');
$sent_info=1;
exit;
} else {
  echo "Звголовки уже были отправлены в $filename в строке $linenum\n";
   die('Повторная отправка данных');
}
?>
0
31 / 45 / 21
Регистрация: 09.10.2012
Сообщений: 825
04.05.2015, 02:28
cubiculus, ошибку то хотя бы напишите

Добавлено через 9 минут
cubiculus, заработало?)
1
14 / 0 / 0
Регистрация: 12.02.2013
Сообщений: 15
04.05.2015, 02:29  [ТС]
Inkvizzz, спасибо, сейчас продолжаю определять переменные через isset и ошибка уже ссылается на ту часть кода, которую тут не отражал (была удалена в попытках выявить ошибку), вероятно после определения всех переменных через isset ошибка исчезнет. Еще раз спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.05.2015, 02:29
Помогаю со студенческими работами здесь

Повторная отправка данных при превышении объема текста
На странице 5.php имеется код: * * * &lt;form action=&quot;index.php?page=6&quot; method=&quot;post&quot; name=&quot;schet&quot;&gt; &lt;input type=&quot;hidden&quot;...

Повторная отправка формы
Добрый день. Есть форма, в которую пользователь должен ввести свое имя и ответ на вопрос, и кнопка, активирующая php-скрипт, проверяющий,...

Повторная отправка формы
Ребята, приветствую вас! Нужна ваша помощь. Начал изучать PHP и MVC (прошу не переносить тему, т.к. вопрос не относится к MVC). Делаю...

Повторная отправка формы
Каким-то образом человек отправил одну и ту же форму в одну секунду. От CSRF защита есть, но везде у него токены разные, однако формы...

Необходима повторная отправка формы
Приветствую. Сайт не большой. Только для своих. На сайте имеется форма отправки, данные которые приходят на почту. Так вот человек вводит...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru