Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP] Problem z $_GET i $_POST
Forum PHP.pl > Forum > Przedszkole
B06US
Najpierw wrzucę cały kod, działa 99%, nie działa tylko 1 rzecz i zmęczony już pisaniem nie mogę dostrzec błędu.. Fajnie by było jak by ktoś świeżym okiem spojrzał bo pewnie od razu zauważy przyczynę.

  1. <?php
  2.  
  3.  
  4. require_once('include/common.php');
  5. require_once('include/edit.php');
  6.  
  7. if (!iMEMBER) { redirect("index.php"); }
  8.  
  9.  
  10.  
  11. $submit_info = array();
  12.  
  13.  
  14.  
  15. $tyt2="Menu";
  16. opentable($tyt2);
  17. <a href='add.php?spis'>Spis Wykładowców</a> |
  18. <a href='add.php?dodaj'>Dodaj Wykładowce</a>";
  19. closetable();
  20.  
  21.  
  22. /*
  23.  * GUI U S U N
  24.  */
  25.  
  26. if (isset($_GET['usun'])) {
  27.  
  28. $result = dbquery("SELECT id, wykladowca, kto, kiedy FROM fusion_pdp_wykladowcy ORDER BY wykladowca ASC LIMIT 111000");
  29.  
  30.  
  31. $kto=mysql_fetch_assoc(mysql_query("SELECT kto FROM fusion_pdp_wykladowcy WHERE id='" . $_GET['usun'] . "'"));
  32. $ko3=$kto['kto'];
  33. dbquery("UPDATE ".DB_USERS." SET points_normal=points_normal-10 WHERE user_id=$ko3");
  34.  
  35. $ktos=mysql_fetch_assoc(mysql_query("SELECT user_name FROM fusion_users WHERE user_id=$ko3"));
  36. $ko33=$ktos['user_name'];
  37.  
  38.  
  39.  
  40. mysql_query("DELETE FROM fusion_pdp_wykladowcy WHERE id='" . $_GET['usun'] . "'");
  41.  
  42.  
  43. opentable("Wykonano");
  44.  
  45. echo "<center>Skasowano wpis: $ko3 wpisany przez $ko33</center>";
  46. closetable();
  47. }
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54. /*
  55.  * GUI S P I S
  56.  */
  57.  
  58. if (isset($_GET['spis'])) {
  59.  
  60.  
  61. $result = dbquery("SELECT id, wykladowca, kto, kiedy FROM fusion_pdp_wykladowcy ORDER BY wykladowca ASC LIMIT 111000");
  62.  
  63. opentable("Spis emaili do wykładowców");
  64.  
  65.  
  66. echo "<table width='100%'>
  67. <tr>
  68. <td> </td>
  69. <td><b>Wykładowca</b></td>
  70. <td><b>Kto</b></td>
  71. <td><b>Kiedy</b></td>
  72. <td> </td>
  73. <td> </td>
  74.  
  75. </tr>";
  76.  
  77.  
  78. $rows = dbrows($result);
  79.  
  80. if ($rows !=0) {
  81.  
  82. while ($row = mysql_fetch_array($result))
  83.  
  84. {
  85.  
  86. echo '<tr><td><img src="'.THEME.'images/bullet.gif" alt=""></td><td> '.$row['wykladowca'].'</td>';
  87.  
  88. $kto=mysql_fetch_assoc(mysql_query("SELECT user_name FROM fusion_users WHERE user_id='".$row['kto']."'"));
  89.  
  90.  
  91. $daj2 = $row['id'];
  92. if(iADMIN) { echo '<td> '.$kto['user_name'].'</td><td> '.showdate("shortdate", $row['kiedy']).' </td><td><a href="add.php?edytuj='.$daj2.'">Edytuj</a></td><td><a href="add.php?usun='.$daj2.'">Skasuj</a></td>';} echo'</tr>';
  93.  
  94. }
  95. echo '</table>';
  96. }
  97. else {
  98. echo '<br />Brak danych do wyświetlenia w spisie - czekamy na Twój pierwszy wpis !'; }
  99. echo '<hr><br>';
  100.  
  101. }
  102.  
  103.  
  104.  
  105.  
  106.  
  107.  
  108. /* --------------------- D O D A J ------------------ */
  109.  
  110.  
  111. if (isset($_GET['dodaj'])) {
  112.  
  113. if (isset($_POST['submit_wykladowca'])) {
  114. if ($_POST['wykladowca'] != "")
  115.  
  116.  
  117. {
  118. $submit_info['wykladowca'] = stripinput($_POST['wykladowca']);
  119.  
  120.  
  121. $result = dbquery("INSERT INTO fusion_pdp_wykladowcy (kto, kiedy, wykladowca) VALUES ('".$userdata['user_id']."', '".time()."', '".addslashes($submit_info['wykladowca'])."' )");
  122. $result = dbquery("UPDATE fusion_users SET points_normal=points_normal +5 WHERE user_id='".$userdata['user_id']."'");
  123.  
  124.  
  125.  
  126.  
  127. opentable("Zakończono dodawanie");
  128. echo "<div style='text-align:center'><br>Dziękujemy za dodanie Nowego wykładowcy<br><br>";
  129. echo "<a href='add.php?dodaj'>Dodaj następny wpis Wykładowcy</a><br /><br />\n";
  130. echo "<a href='index.php'>Idz na główną</a><br /><br />\n</div>\n";
  131. closetable();
  132. }
  133. } else {
  134. $opts = "";
  135.  
  136. $tyt="Dodaj Wykładowce";
  137.  
  138. opentable($tyt);
  139.  
  140.  
  141.  
  142.  
  143. echo "Wypełnij formularz<br><br>\n";
  144.  
  145.  
  146. echo "<form name='submit_form' method='post' action='".FUSION_SELF."?dodaj' onsubmit='return validateLink(this);'>\n";
  147.  
  148.  
  149. echo "<table cellpadding='0' cellspacing='0' class='center'>\n";
  150.  
  151.  
  152.  
  153.  
  154.  
  155. echo "<td class='tbl'>Nazwisko i Imię wykladowcy</td>\n";
  156. echo "<td class='tbl'><input type='text' name='wykladowca' maxlength='100' class='textbox' style='width:300px;' /></td>\n";
  157. echo "</tr>\n<tr>\n";
  158.  
  159.  
  160. echo "<td align='center' colspan='2' class='tbl'><br />\n";
  161. echo "<input type='submit' name='submit_wykladowca' value='Dodaj' class='button' />\n</td>\n";
  162. echo "</tr>\n</table>\n</form>\n";
  163.  
  164. echo "Zaczynaj z dużej litery: <b>N</b>azwisko i <b>I</b>mię. <br /> Jeli nazwisko dwu - członowe oddzielaj je za pomocą <b>-</b> (milnika) ze spacią przed i po.<br />";
  165.  
  166.  
  167.  
  168. closetable();
  169. }
  170.  
  171.  
  172.  
  173.  
  174.  
  175. }
  176.  
  177.  
  178.  
  179.  
  180. /* ---------------------E D Y T U J---------------- */
  181.  
  182.  
  183. if (isset($_GET['edytuj'])) {
  184.  
  185. if (isset($_POST['submit_wykladowca'])) {
  186. if ($_POST['wykladowca'] != "")
  187.  
  188.  
  189. {
  190. $submit_info['wykladowca'] = stripinput($_POST['wykladowca']);
  191.  
  192.  
  193. $wwwa = mysql_fetch_assoc(mysql_query("SELECT id FROM fusion_pdp_wykladowcy WHERE id='" . $_GET['edytuj'] . "'"));
  194. $wwwaa = $wwwa['id'];
  195. $e = $_GET['edytuj'];
  196. $result= dbquery("UPDATE fusion_pdp_wykladowcy SET wykladowca='".$submit_info['wykladowca']."' WHERE id=$wwwaa");
  197.  
  198.  
  199. opentable("Zakończono edytowanie");
  200. echo "<div style='text-align:center'><br>Dziękujemy za poprawienie danych o wykładowcy $wwwaa $e<br><br>";
  201. echo "<a href='add.php?dodaj'>Dodaj nowy wpis Wykładowcy</a><br /><br />\n";
  202. echo "<a href='index.php'>Idz na główną</a><br /><br />\n</div>\n";
  203. closetable();
  204. }
  205. } else {
  206. $opts = "";
  207.  
  208. $tyt="Edytuj Wykładowce";
  209.  
  210. opentable($tyt);
  211.  
  212.  
  213.  
  214.  
  215. echo "Wypełnij formularz<br><br>\n";
  216.  
  217.  
  218. echo "<form name='submit_form' method='post' action='".FUSION_SELF."?edytuj' onsubmit='return validateLink(this);'>\n";
  219.  
  220.  
  221. echo "<table cellpadding='0' cellspacing='0' class='center'>\n";
  222.  
  223.  
  224.  
  225.  
  226.  
  227. echo "<td class='tbl'>Nazwisko i Imię wykladowcy</td>\n";
  228. $www=mysql_fetch_assoc(mysql_query("SELECT wykladowca FROM fusion_pdp_wykladowcy WHERE id='" . $_GET['edytuj'] . "'"));
  229.  
  230. echo "
  231. <td class='tbl'><input type='text' name='wykladowca' value='".$www['wykladowca']."' maxlength='100' style='width:300px;'></td>\n";
  232. echo "</tr>\n<tr>\n";
  233.  
  234.  
  235. echo "<td align='center' colspan='2' class='tbl'><br />\n";
  236. echo "<input type='submit' name='submit_wykladowca' value='Edytuj' class='button' />\n</td>\n";
  237. echo "</tr>\n</table>\n</form>\n";
  238.  
  239. echo "Zaczynaj z dużej litery: <b>N</b>azwisko i <b>I</b>mię. <br /> Jeli nazwisko dwu - członowe oddzielaj je za pomocą <b>-</b> (mylnika) ze spacią przed i po.<br />";
  240.  
  241.  
  242.  
  243. closetable();
  244. }
  245.  
  246.  
  247.  
  248.  
  249.  
  250. }
  251.  
  252.  
  253. echo "<script type='text/javascript'>
  254. function validateLink(frm) {
  255. if (frm.link_name.value==\"\" || frm.link_name.value==\"\" || frm.link_description.value==\"\") {
  256. alert(\"Uzupełnij wszystkie pola !\"); return false;
  257. }
  258. }
  259.  
  260. </script>\n";
  261.  
  262.  
  263.  
  264.  
  265.  
  266.  
  267. require_once('include/die.php');
  268. ?>


Natomiast w zasadzie "użeram się z tą częściąkodu:
  1.  
  2. $wwwa = mysql_fetch_assoc(mysql_query("SELECT id FROM fusion_pdp_wykladowcy WHERE id='" . $_GET['edytuj'] . "'"));
  3. $wwwaa = $wwwa['id'];
  4.  
  5. $result= dbquery("UPDATE fusion_pdp_wykladowcy SET wykladowca='".$submit_info['wykladowca']."' WHERE id=$wwwaa");


Chodzi o to że nie zapisuje mi zmian do bazy ... i wyskakuje błąd.. (You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1) próbowałem na kilka sposobów.. problem wynika tu z
  1. WHERE id='" . $_GET['edytuj'] . "'"));
, nie chce mi zwrócić wartości GET mimo że identyczny kod w innych częściach tego pliku działa..
nospor
Cytat
nie chce mi zwrócić wartości GET mimo że identyczny kod w innych częściach tego pliku działa..
Kurcze... no ale nie można bezmyślnie skopiować jakis fragment z jednego kawałka i wkleić do drugiego.... tam ci działało bo tam w url miałeś to EDYTUJ. Tutaj skolei panie kolego nie masz tego EDYTUJ

Twój form wyglada tak:
echo "<form name='submit_form' method='post' action='".FUSION_SELF."?edytuj' onsubmit='return validateLink(this);'>\n";
Więc ty w url przekazujesz sam tekst EDYTUJ. A gdzie jego wartosc? Nie ma.
B06US
noo jaaa ale gafa... xP Dziękuje ślicznie ! Byłem pewny że świeże oko zobaczy więcej.
nospor
No ale co ma do tego świeże oko? Nie ma $_GET['edytuj'] wartosci to się patrzy czemu nie ma i tyle w temacie.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.