Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

2 Stron V   1 2 >  
Reply to this topicStart new topic
> [PHP]Logowanie nie działa.
marian2299
post 17.08.2009, 22:33:29
Post #1





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Napisałem sobie logowanie, u mnie ok.ALe musiałem podłożyć koledze, on wydziwia z kodem strasznie, ale do rzeczy:
  1. <?php include "antet.php"; include "func.php";
  2.  
  3. $gen_stats=gen_stats(48);
  4. ?>
  5.  
  6. <html>
  7. <head>
  8. <title><?php echo $title; ?></title>
  9. <link type="text/css" rel="Stylesheet" href="/css/magia-gra.css" />
  10. <link rel="shortcut icon" href="../images/logo.png" />
  11.  
  12. </script>
  13.  
  14. </head>
  15. <body><br>
  16. <div id='okno'>
  17. <a href='../index.php'><div id='start' class='block'></div></a>
  18. <div id='one' class='block'>
  19. <table>
  20.  
  21.  
  22. <?php
  23. if($_GET['akcja']!="")
  24. {
  25. switch( $_GET['akcja']) {
  26.  
  27. case 'loguj':
  28. include 'logowanie_.php';
  29. break;
  30.  
  31.  
  32. }
  33. }
  34. if ($_SESSION['zalogowany'] == true) {
  35. echo "Zostałeś zalogowany jako: ".$_SESSION['login']."";
  36. }
  37. elseif (isset($_POST['submit'])) {
  38. if($_POST['login'] !="" || $_POST['haslo'] !=""){
  39. $login = mysql_real_escape_string($_POST['login']); //określenie zmiennej login, dodanie backshalsy
  40. $haslo = md5($_POST['haslo']); //określenie zmiennej haslo, kodowanie md5
  41. $zapytanie = "SELECT * FROM `gracze` WHERE login=". $login." and haslo=".$haslo." "; //zapytanie
  42. $uzytkownik = mysql_query($zapytanie) or die("Wystąpił nieoczekiwany błąd."); //wynik zapytania
  43. $uzytkownik = mysql_fetch_array($uzytkownik) or die("Wystąpił nieoczekiwany błąd.");
  44.  
  45. if($uzytkownik['login'] === $login && $uzytkownik['haslo'] === $haslo){
  46.  
  47. $_SESSION['zalogowany'] = true; //określamy zmienną sesyjną zalogowany
  48. $_SESSION['login'] = $uzytkownik['login']; //określamy zmienną sesyjną login
  49.  
  50. echo "Zostałeś zalogowany jako: ".$_SESSION['login'].""; //jeśli wszystko ok, wyświetlamy login
  51. }
  52. else {
  53. echo 'Podałeś błędne dane, spróbuj ponownie.'; //jeśli wprowadzono złe dane, błąd
  54. }
  55.  
  56.  
  57. }
  58. else { echo 'Uzupełnij wszystkie pola!';}
  59. }
  60.  
  61. else {
  62. echo '<form action="?" method="post">
  63. <table><tr>
  64. <td><label><small>Gracz</small></td>
  65. <td><input type="text" name="login" ><td>
  66. </label> </tr>
  67. <tr>
  68. <td><label><small>Hasło</small></td>
  69. <td><input type="password" name="haslo"></td>
  70. </label></tr>
  71. </table>
  72. <label><center>
  73. <input type="submit" name="submit" value="Zaloguj">
  74. </label></center>
  75.  
  76. </form>'; }

I mam: Wystąpił nieoczekiwany błąd.
Jakieś pomysły tongue.gif ?

Ten post edytował marian2299 17.08.2009, 22:39:43


--------------------
film edit student
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 22:40:57
Post #2





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


A może łaskawie napiszesz jaki błąd? snitch.gif


--------------------
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 22:46:00
Post #3





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


  1. #
  2. $uzytkownik = mysql_query($zapytanie) or die("Wystąpił nieoczekiwany błąd."); //wynik zapytania
  3. #
  4. $uzytkownik = mysql_fetch_array($uzytkownik) or die("Wystąpił nieoczekiwany błąd.");

Na początku miałem coś "wystąpił nieoczekiwany błąd" w kodzie jako else, dlatego się pogubiłem. Więc dlaczego mysql_fetch_array się nie chce wykonać ?

Ten post edytował marian2299 17.08.2009, 22:47:17


--------------------
film edit student
Go to the top of the page
+Quote Post
jmail
post 17.08.2009, 22:47:33
Post #4





Grupa: Zarejestrowani
Postów: 352
Pomógł: 53
Dołączył: 10.08.2009

Ostrzeżenie: (0%)
-----


linia 42

  1.  
  2. $zapytanie = "SELECT * FROM `gracze` WHERE login=". $login." and haslo=".$haslo." "; //zapytanie
  3.  


nie masz apostrofów obejmujących login i hasło a jak podejrzewam to są varchars
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 22:56:29
Post #5





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Wiesz, że je miałem haha.gif ? Ale usunąłem haha.gifd. Już patrzę...

  1. $zapytanie = "SELECT * FROM `gracze` WHERE login=" '. $login.' " and haslo=" '.$haslo.' " "; //zapytanie

Doesn't work. Cały czas nieoczekiwany błąd.


--------------------
film edit student
Go to the top of the page
+Quote Post
Wicepsik
post 17.08.2009, 22:57:42
Post #6





Grupa: Zarejestrowani
Postów: 1 575
Pomógł: 299
Dołączył: 26.03.2009

Ostrzeżenie: (20%)
X----


mysql_error


--------------------
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 22:58:57
Post #7





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


Tak
  1. $zapytanie = "SELECT * FROM `gracze` WHERE login='$login' and haslo='$haslo'"; //zapytanie


--------------------
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 23:05:28
Post #8





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Kod nie działa, a mysql error nic nie daje, jakiś inny powód ?
Dałem:
  1. $login = mysql_real_escape_string($_POST['login']); //określenie zmiennej login, dodanie backshalsy
  2. $haslo = md5($_POST['haslo']); //określenie zmiennej haslo, kodowanie md5
  3. echo $login;echo $haslo;

I dane były w porządku.


--------------------
film edit student
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 23:11:22
Post #9





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


A gdzie mysql_connect?


--------------------
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 23:16:02
Post #10





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Jestem trochę n00bem, bo powinno być nick zamiast login. Teraz pokazuje "Podałeś błędne dane..." jednak podałem dobre.
  1. <?php include "antet.php"; include "func.php";
  2.  
  3. $gen_stats=gen_stats(48);
  4. ?>
  5.  
  6. <html>
  7. <head>
  8. <title><?php echo $title; ?></title>
  9. <link type="text/css" rel="Stylesheet" href="/css/magia-gra.css" />
  10. <link rel="shortcut icon" href="../images/logo.png" />
  11.  
  12. </script>
  13.  
  14. </head>
  15. <body><br>
  16. <div id='okno'>
  17. <a href='../index.php'><div id='start' class='block'></div></a>
  18. <div id='one' class='block'>
  19. <table>
  20.  
  21.  
  22. <?php
  23. if($_GET['akcja']!="")
  24. {
  25. switch( $_GET['akcja']) {
  26.  
  27. case 'loguj':
  28. include 'logowanie_.php';
  29. break;
  30.  
  31.  
  32. }
  33. }
  34. if ($_SESSION['zalogowany'] == true) {
  35. echo "Zostałeś zalogowany jako: ".$_SESSION['login']."";
  36. }
  37. elseif (isset($_POST['submit'])) {
  38. if($_POST['login'] !="" || $_POST['haslo'] !=""){
  39. $login = mysql_real_escape_string($_POST['login']); //określenie zmiennej login, dodanie backshalsy
  40. $haslo = md5($_POST['haslo']); //określenie zmiennej haslo, kodowanie md5
  41. $zapytanie = "SELECT * FROM `gracze` WHERE nick='$login' and haslo='$haslo'"; //zapytanie
  42. $uzytkownik = mysql_query($zapytanie) or die("Wystąpił nieoczekiwany błąd."); //wynik zapytania
  43. $uzytkownik = mysql_fetch_array($uzytkownik) or die("Wystąpił nieoczekiwany błąd.");
  44.  
  45. if($uzytkownik['login'] === $login && $uzytkownik['haslo'] === $haslo){
  46.  
  47. $_SESSION['zalogowany'] = true; //określamy zmienną sesyjną zalogowany
  48. $_SESSION['login'] = $uzytkownik['login']; //określamy zmienną sesyjną login
  49.  
  50. echo "Zostałeś zalogowany jako: ".$_SESSION['login'].""; //jeśli wszystko ok, wyświetlamy login
  51. }
  52. else {
  53. echo 'Podałeś błędne dane, spróbuj ponownie.'; //jeśli wprowadzono złe dane, błąd
  54. }
  55.  
  56.  
  57. }
  58. else { echo 'Uzupełnij wszystkie pola!';}
  59. }
  60.  
  61. else {
  62. echo '<form action="?" method="post">
  63. <table><tr>
  64. <td><label><small>Gracz</small></td>
  65. <td><input type="text" name="login" ><td>
  66. </label> </tr>
  67. <tr>
  68. <td><label><small>Hasło</small></td>
  69. <td><input type="password" name="haslo"></td>
  70. </label></tr>
  71. </table>
  72. <label><center>
  73. <input type="submit" name="submit" value="Zaloguj">
  74. </label></center>
  75.  
  76. </form>'; }
  77.  
  78. ?>


Ten post edytował marian2299 17.08.2009, 23:20:17


--------------------
film edit student
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 23:19:42
Post #11





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


Jeżeli masz nadal "Wystąpił nieoczekiwany błąd." to sprawdź bazę danych i połączenia.
  1. #
  2. $uzytkownik = mysql_query($zapytanie) or die("Wystąpił nieoczekiwany błąd."); //wynik zapytania
  3. #
  4. $uzytkownik = mysql_fetch_array($uzytkownik) or die("Wystąpił nieoczekiwany błąd.");

2 razy ta sama zmienna, zmień nazwę.

Ten post edytował Andaramuxo 17.08.2009, 23:22:47


--------------------
Go to the top of the page
+Quote Post
jmail
post 17.08.2009, 23:20:36
Post #12





Grupa: Zarejestrowani
Postów: 352
Pomógł: 53
Dołączył: 10.08.2009

Ostrzeżenie: (0%)
-----


tej. czkeaj czekaj. a Ty masz jakiekolwiek dane w tej tabeli?
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 23:26:43
Post #13





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Andaramuxo, inne zapytania, a nawet inne mysql_fetch_array się wykonują na tej stronie.
Dałem: $uzytkownik = mysql_fetch_array(mysql_query($zapytanie)) or die("Wystąpił nieoczekiwany błąd."); // tablica, ale żadnych zmian.
jmail, mam winksmiley.jpg. Nick: adimil haslo: 4e1b5180735a3ddc843c069de4df0a38.

Ten post edytował marian2299 17.08.2009, 23:28:50


--------------------
film edit student
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 23:30:15
Post #14





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


session_start() daj na sam początek skryptu...

@down

Patrz mój poprzedni post. smile.gif

Ten post edytował Andaramuxo 17.08.2009, 23:31:42


--------------------
Go to the top of the page
+Quote Post
jmail
post 17.08.2009, 23:30:17
Post #15





Grupa: Zarejestrowani
Postów: 352
Pomógł: 53
Dołączył: 10.08.2009

Ostrzeżenie: (0%)
-----


chwila myślę tongue.gif

a tak?

  1.  
  2. $zapytanie = 'SELECT * FROM gracze WHERE nick=\''.$login.'\' and haslo=\''.$haslo.'\''; //zapytanie
  3. $uzytkownik = mysql_fetch_array(mysql_query($zapytanie)) or die("Wystąpił nieoczekiwany błąd."); //wynik zapytania
  4.  
  5.  


Ten post edytował jmail 17.08.2009, 23:32:48
Go to the top of the page
+Quote Post
dadexix
post 17.08.2009, 23:31:46
Post #16





Grupa: Zarejestrowani
Postów: 439
Pomógł: 21
Dołączył: 28.06.2007
Skąd: Bielsko-Biała

Ostrzeżenie: (0%)
-----


probowales uzyc mysql_error?


  1. $uzytkownik = mysql_query($zapytanie) or die(mysql_error()); //wynik zapytania
  2.  
  3. $uzytkownik = mysql_fetch_array($uzytkownik) or die(mysql_error());


Mozesz tez dac jakies numerki by wiedziec gdzie sie sypie

  1. $uzytkownik = mysql_query($zapytanie) or die("Blad 1<br>".mysql_error()); //wynik zapytania
  2.  
  3. $uzytkownik = mysql_fetch_array($uzytkownik) or die("Blad 2<br>".mysql_error());




--------------------
"Na przykład zmiennej $jestem_najlepszy przypisujemy wartość logiczną TRUE"
Ja: użyj funkcji[...]
Grins: mów normalnie do mnie a nie po polsku
Ja: normalnie to znaczy jak?
Grins: No w PHP... inaczej mój parser ledwo kuma:)
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 23:34:36
Post #17





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Z tym mysql_fetch_array jest w porządku. Teraz jednak wpisując POPRAWNE dane mam "Podałeś błędne dane, spróbuj ponownie.".

Ten post edytował marian2299 17.08.2009, 23:38:10


--------------------
film edit student
Go to the top of the page
+Quote Post
Andaramuxo
post 17.08.2009, 23:37:24
Post #18





Grupa: Zarejestrowani
Postów: 150
Pomógł: 15
Dołączył: 18.03.2009

Ostrzeżenie: (10%)
X----


Trudny nick=A-xo, daj session_start() tam przy zmiennej $_GET['akcja'] i napisz co wywala mysql_error.


--------------------
Go to the top of the page
+Quote Post
jmail
post 17.08.2009, 23:43:51
Post #19





Grupa: Zarejestrowani
Postów: 352
Pomógł: 53
Dołączył: 10.08.2009

Ostrzeżenie: (0%)
-----


i moze na odświeżenie wklej nowy kod. tak jak masz teraz
Go to the top of the page
+Quote Post
marian2299
post 17.08.2009, 23:55:53
Post #20





Grupa: Zarejestrowani
Postów: 272
Pomógł: 9
Dołączył: 6.06.2009

Ostrzeżenie: (0%)
-----


Więc tak, pomylenie login z nick ciąg dalszy:
  1. <?php
  2. include "antet.php"; include "func.php";
  3.  
  4. $gen_stats=gen_stats(48);
  5. ?>
  6.  
  7. <html>
  8. <head>
  9. <title><?php echo $title; ?></title>
  10. <link type="text/css" rel="Stylesheet" href="/css/magia-gra.css" />
  11. <link rel="shortcut icon" href="../images/logo.png" />
  12.  
  13. </script>
  14.  
  15. </head>
  16. <body><br>
  17. <div id='okno'>
  18. <a href='../index.php'><div id='start' class='block'></div></a>
  19. <div id='one' class='block'>
  20. <table>
  21.  
  22.  
  23. <?php
  24.  
  25. if($_GET['akcja']!="")
  26. {
  27. switch( $_GET['akcja']) {
  28.  
  29. case 'loguj':
  30. include 'logowanie_.php';
  31. break;
  32.  
  33.  
  34. }
  35. }
  36. if ($_SESSION['zalogowany'] == true) {
  37. echo "Zostałeś zalogowany jako: ".$_SESSION['login']."";
  38. }
  39. elseif (isset($_POST['submit'])) {
  40. if($_POST['nick'] !="" || $_POST['haslo'] !=""){
  41. $login = mysql_real_escape_string($_POST['nick']); //określenie zmiennej login, dodanie backshalsy
  42. $haslo = md5($_POST['haslo']); //określenie zmiennej haslo, kodowanie md5
  43. $zapytanie = "SELECT * FROM `gracze` WHERE nick='$login' and haslo='$haslo'"; //zapytanie
  44. $uzytkownik = mysql_fetch_array(mysql_query($zapytanie)) or die("Wystąpił nieoczekiwany błąd: ".mysql_error());// tablica
  45. if($uzytkownik['login'] === $login && $uzytkownik['haslo'] === $haslo){
  46.  
  47. $_SESSION['zalogowany'] = true; //określamy zmienną sesyjną zalogowany
  48. $_SESSION['login'] = $uzytkownik['login']; //określamy zmienną sesyjną login
  49.  
  50. echo "Zostałeś zalogowany jako: ".$_SESSION['login'].""; //jeśli wszystko ok, wyświetlamy login
  51. }
  52. else {
  53. echo 'Podałeś błędne dane, spróbuj ponownie.'; //jeśli wprowadzono złe dane, błąd
  54. }
  55.  
  56.  
  57. }
  58. else { echo 'Uzupełnij wszystkie pola!';}
  59. }
  60.  
  61. else {
  62. echo '<form action="?" method="post">
  63. <table><tr>
  64. <td><label><small>Gracz</small></td>
  65. <td><input type="text" name="login" ><td>
  66. </label> </tr>
  67. <tr>
  68. <td><label><small>Hasło</small></td>
  69. <td><input type="password" name="haslo"></td>
  70. </label></tr>
  71. </table>
  72. <label><center>
  73. <input type="submit" name="submit" value="Zaloguj">
  74. </label></center>
  75.  
  76. </form>'; }
  77.  
  78. ?>

Aktualnie wywala mi nieoczekiwany błąd, bez mysql errora -.-.
I ugu padło (robię na testowym -.-) cały świat przeciw mnie haha.gif.
Poprawiłem $_POST['login'] na nick, ale błąd jest jeszcze przed. Znowu to fetch_array.


--------------------
film edit student
Go to the top of the page
+Quote Post

2 Stron V   1 2 >
Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 16.05.2024 - 21:20