Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Problem z walką z graczem - bład
Forum PHP.pl > Forum > PHP
awek520
Witam. Tworzę taki mały system walki z innymi graczami..

Mam tabele users, gdzie wszystkie dane są zapisane.. No i wyciągłem informacje z bazy o przeciwniku i o atakującym.. No ale ciągle wyskakuje mi że dany gracz nie istnieje.. i można też siebie tak jakby zaatakowac.. a teraz mam taki bład..

  1. Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE, expecting T_STRING or T_VARIABLE or T_NUM_STRING in C:\WebServ\httpd\wal_gracz.php on line 10


Oto kod:

  1. <?php
  2. if ($_POST['przeciwnik']!='' && $_POST['przeciwnik']!=$_SESSION['login']){
  3. $przeciwnik=mysql_query("SELECT * FROM users WHERE login=$_POST[$przeciwnik] LIMIT 1");
  4.  
  5. if(mysql_num_rows($przeciwnik)!==1){
  6. echo 'Taki gracz nie istnieje!';
  7. }
  8. else {
  9.  
  10. $atakujacy=mysql_query("SELECT * FROM users WHERE login='$_SESSION['login']' LIMIT 1");
  11. $atakujacy=mysql_fetch_assoc($atakujacy);
  12. $przeciwnik=mysql_fetch_assoc($przeciwnik);
  13.  
  14. }
  15.  
  16. }
  17. else if ($_POST['login']!=''){
  18. echo 'Nie możesz atakowac siebie!';
  19. }
  20.  
  21. ?>
  22.  
  23.  
  24.  
  25. <form name="input" action="game.php?a=wal_gracz" method="post">
  26. Przeciwnik: <input type="text" name="przeciwnik" /><br>
  27. <input type="submit" value="Atakuj">
  28. </form>



Co jest nie tak ?
daniel1302
  1. $atakujacy=mysql_query("SELECT * FROM users WHERE login='$_SESSION['login']' LIMIT 1");

zmien na
  1. $atakujacy=mysql_query("SELECT * FROM users WHERE login='".$_SESSION['login']."' LIMIT 1");
Wazniak96
Kolego dzieje się tak ponieważ dałeś apostrofy w apostrofach w linijce numer 10.
  1. $atakujacy=mysql_query("SELECT * FROM users WHERE login='".$_SESSION['login']."' LIMIT 1");


PS: wyciągnąłem* smile.gif
awek520
No działa działa smile.gif

Ale dalej mam problem z tym.. że obojętnie jaki nick wpisze.. zawsze jest błąd że dany użytkonwik nie istnieje.. no i można samego siebie atakowac..


PS: wyciągnąłem* - racja.. Jestem z śląska.. a do tego dyslektyk ; /
daniel1302
1) Sprawdź jak zabezpieczyć skeypt przed SQL INJECTION
2) Przeczytaj poradnik PHP i zabieraj sie za pisanie gier. Ja kiedyś testowałem grę gdzie ktoś sobie dodawał kase nonstop i nie wiadomo gdzie, testowaliśmy zmienne po koleji i wykryliśmy 2 błędy SQL injection ale to nie było to, bo proceder dalej był aktualny, okozało się po nasłuchu danego usera i sprawdzeniu co robi akcja po akcji, że sprzedawał niesttniejące przedmioty. Więc ludzie nieźle kombinują i wbrew pozorom nie tylko laicy grają w viawww.
3) Linię:
  1. $przeciwnik=mysql_query("SELECT * FROM users WHERE login=$_POST[$przeciwnik] LIMIT 1");

zmień na
  1. $przeciwnik=mysql_query("SELECT * FROM users WHERE login='".$_POST[$przeciwnik]."' LIMIT 1");


Jeśli wstawiasz jakiś tekst do zapytania SQL musi on być w apostrofie '

http://multimedia.journalism.berkeley.edu/...ning-variables/


Wazniak96
1. Nie $_POST[$przeciwnik] a $_POST['przeciwnik'], daniel trochę uwagi smile.gif
2. Nie sprawdzasz bardzo ważnego warunku, a raczej robisz to źle. isset empty
3. W twoim skrypcie nie widzę session_start stąd wnioskuję, że sesja nie zaeiera twojego nicku bo nie zostala otworzona. Do tego Wazniak != WAZNIAK dlatego użyj strtolower tongue.gif
4. Używar raczej mysql_num_rows($query) == 0
awek520
Ok, dziękujemy każdemu smile.gif cały skrypcik działa dobrze wink.gif
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.