Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][HTML][PHP] Przekazanie danych bez formularza
Forum PHP.pl > Forum > Przedszkole
Lucky Luke
Witam, robię skrypt z którego mogą korzystać użytkownicy zarejestrowani i nie zarejestrowani. Chcę zrobić edycję pewnych danych które wcześniej zarejestrowany użytkownik dodał do bazy ale ta edycja pomija zapytanie o hasło dla nie zarejestrowanych. Działać działa ale nie wczytuje mi tych danych które chcę, mianowicie chcę, żeby edytowało mi dane z id (rekordu) np. 20 (gdzie login dodającego=loginowi zalogowanego) ale nie przekazuje mi zmiennych i wczytuje inne id tego samego zarejestrowanego użytkownika. Gdzie zrobiłem błędy w kodzie?
Plik który prosi o hasło do danego rekordu dla niezarejestrowanych a dla zalogowanych ma go pominąć
  1. ...//część kodu
  2. $id_get = mysql_escape_string($id_get);
  3. $zap = mysql_query("SELECT * FROM baza WHERE idnum='$id_get'");
  4. echo $html_head;
  5. echo $html_naglowek;
  6. echo '<div id="content">';
  7. if($login = $_SESSION['nick']){
  8. echo'przekierownie jesli zalogowany
  9. <input type="hidden" name="edit_id" value="'.$id_get.'" size="10" class="formst">
  10. <META HTTP-EQUIV="Refresh" CONTENT="3; URL=index.php?akcja=edycja_form">
  11. ';
  12. }
  13. else
  14. <TABLE BORDER=0 WIDTH=750 bgcolor=#EBEBEB cellspacing=1 cellpadding=1>
  15. <TR>
  16. <TD align=right width=50% height=25>
  17. <form action="index.php?akcja=edycja_form" method="post">
  18. <input type="hidden" name="idnum" value="'.$idnum.'">
  19. ...
  20. <input type="text" name="edit_id" value="'.$id_get.'" size="10" class="formst">
  21. ...//dalej jest formularz podania hasła do rekordu dla nie zarejestrowanych


Plik które pokazuje dane rekordu
  1. ...//początkowa część kodu
  2. $id_get = mysql_escape_string($id_get);
  3. $zap = mysql_query("SELECT * FROM baza WHERE idnum Like '%".$_POST['edit_id']."%' ");
  4. while($rek = mysql_fetch_array($zap)) {
  5. $email = $rek[12];
  6. }
  7. echo '<div id="content">';
  8. if(($login = $_SESSION['nick']) or ($passw === $_POST['passw'])){
  9.  
  10. ...//dalsza częśc kodu
  11. }


Zapewne błąd jest tutaj ale nie wiem jak to sformułować sad.gif
  1. if($login = $_SESSION['nick']){
  2. echo'przekierownie jesli zalogowany
  3. <input type="hidden" name="edit_id" value="'.$id_get.'" size="10" class="formst">
  4. <META HTTP-EQUIV="Refresh" CONTENT="3; URL=index.php?akcja=edycja_form">
  5. ';
  6. }
  7. else
sadistic_son
Ne sprawdzałem dokładnie kodu, tylko z grubsza przejrzałem ale co od razu rzuca się w oczy to
  1. if($login = $_SESSION['nick']){
a powinno być
  1. if($login == $_SESSION['nick']){
Lucky Luke
Cytat(sadistic_son @ 28.04.2011, 18:46:05 ) *
Ne sprawdzałem dokładnie kodu, tylko z grubsza przejrzałem ale co od razu rzuca się w oczy to
  1. if($login = $_SESSION['nick']){
a powinno być
  1. if($login == $_SESSION['nick']){


tak, tylko jak dam
  1. if($login == $_SESSION['nick']){
to wykonuje się to co jest po else czyli zapytanie o hasło (ustawione wcześniej) do rekordu a ja chcę zrobić tak, żeby pomijało to zapytanie o hasło jeśli użytkownik jest zalogowany ale nie wiem jak przekazać zmienną 'edit_id' bez formularza.
modern-web
Przekaż ją w sesji... Lub w pasku adresu - $_GET
Kszysiu
ja mam małe pytanko do tego co napisał modern-web.
napisałeś coś o przekazywaniu zmiennych.
Da się przekazać zmienną _GET
a da się jakoś przekazać do następnej strony zmienną w _POST? albo jakoś coś w podobie do tego? wink.gif
hieroshima
metoda POST jest formą interakcyjną z użytkownikiem, która nie może być w formie adresu czyli metoda GET. Zostaje tylko formularz smile.gif POST działa tylko z formularzami
Kszysiu
aha dzięki.
Czyli nie da się w sposób "niewidoczny" przesłać danych z jednej strony do drugiej? oczywiście nie mówie o sesjach wink.gif
hieroshima
w zasadzie jest taki sam temat w dziale PHP dam tu ten sam link co tam, ale nie jestem pewny czy to działa i czy jest bezpieczne --> POST BEZ FORMULARZA
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.