Temos pavadinimas: WordPress, Shopify ir PHPFusion programuotojų bendruomenė :: Del php prisijungimo.

Parašė 1dEo· 2011 Bir. 21 22:06:27
#1

Sveiki, taigi noriu ismokti padaryti prisijungima su php turiu susikures lentele duomenubazeje esu pasidares prisijugima prie DB na vienu zodziu turiu ko reikia.

Turiu login.php


 
<?php
 
echo "<form name='prisijungimas' action='prisijungimas.php'>";
 
echo "<h3>Prisijungti</h3>";
 
echo "Vardas: <input type='text' size='20'>";
 
echo "<br>";
 
echo "Slaptazodis: <input type='password' size='20'>";
 
echo "<br>";
 
echo "<input type='submit' value='Prisijungti'>";
 
echo "</form>";
 
?>


Dabar noriu, kad pavyzdziui ivedus tikraji admin nick ir spaltazodi pavyzdziui Admin Admin mane mestu i balta lapa na viskas tvarkoj butu? gal galetumet pasakyt nuo ko pradet prisijungimas.php, kad vat sitas suveiktu normaliai. Aciu, jei padesite arba bent uzvesite ant kelio.

Nepagaliesiu +11

Redagavo 1dEo· 2011 Bir. 21 22:06:01

Parašė avice· 2011 Bir. 21 22:06:20
#2

http://www.phpeasystep.com/phptu...

Parašė Faitas.· 2011 Bir. 21 23:06:56
#3

Sveikas. Aš dirbu su framework'u, todėl ir tau patarčiau tai išbandyti. Bet paaiškinsiu ir su PHP :)

Pirmiausia turėtum parašyti tvarkingą prisijungimo formą:

login.php


<html>
<head><title>Prisijungimas</title></head>
<body>
 
<form action='login_check.php' method='post'>
Vardas:<br />
<input type='text' name='username' maxlength='30'><br /><br />
Slaptažodis:<br />
<input type='password' name='password' maxlength='50'><br /><br />
<input type='submit' name='login' value='Prisijungti'>
</form>
 
</body>
</html>


PASTABA: Niekados nenaudok GET duomenims gauti :) Nes GET funkcija atvaizduoja gaunamus duomenis naršyklės URL'e

Toliau reikia failo, kuris tikrintų visus duomenis :)

login_check.php


<?php
 
//Gauname visus duomenis
$username = $_POST['username'];
$password = $_POST['password'];
 
//Tikriname ar lankytojas įvedė tikrai visus duomenis
$check = TRUE; // Tikrinimo kintamasis
$msg = ""; // Teksto (string) kintamasis, į kurį rašysime klaidas
 
if(!isset($username))
{
$check = FALSE; // Klaida? Nustatome check kintamąjam FALSE reikšme
$msg = $msg . "Jūs pamiršote įvesti vartotojo vardą<br />";
}
if(!isset($password))
{
$check = FALSE; // Klaida? Nustatome check kintamąjam FALSE reikšme
$msg = $msg . "Jūs pamiršote įvesti slaptažodį<br />";
}
 
//Tikriname ar viskas gerai
if($check == FALSE)
{
//Juk check kintamasis yra FALSE, tai reiškia, kad įvyko klaida.
echo $msg;
}
else
{
//Nustatome sesijos kintamuosius
$_SESSION['username'] = $username;
 
//Išvedame sakinį
echo "Sveikas, " . $_SESSION['username'];
}
 
?>


Na, dar keletas patarimų. :) Jei darysi duomenų gavimą iš duom.bazės, tai daryk su funkcijomis. Funkcijos veikia taip:


<?php
 
function pirmoji_funcija($kintamasis1, $kintamasis2)
{
$sum = $a + $b;
 
return $sum;
}
 
?>


$kintamasis1, $kintamasis2 yra nebūtini. :) Taip pat, return gražina reikšmę, šiuo atvėju būtų taip:


<?php
 
$a = 10;
$b = 55;
 
echo pirmoji_funcija($a, $b); // Mums išvestų $sum kintamojo reikšmę.
 
?>


Tai tiek šiam kartui. Sekmės kuriant.

Parašė 1dEo· 2011 Bir. 21 23:06:34
#4

Aciu padejot :). Avice skripta duot dar suprantu, bet Faito tai jo dar gilintis biski reikes gaunat +11. Kilus kilusius klausimus su php klausiu cia.

Redagavo 1dEo· 2011 Bir. 21 23:06:49

Parašė Faitas.· 2011 Bir. 21 23:06:33
#5

Be gilinimosi nebus ir rezultato. O, kad kodą pakopinsi ir įdėsi, tai nuo to tau geriau nebus ;)

Dar kartą, sekmės kurime. :)

Parašė 1dEo· 2011 Bir. 22 23:06:40
#6

Sveiki, taigi susiduriau su beda. Bandziau bandziau ja isspresti ir visvien taspats

Stai kokia klaida:


Warning: mysql_num_rows(): supplied argument is not a valid <span style="border-bottom: 1px dotted black;">MySQL</span> result resource in /home/testavimas/domains/testavimas.us.lt/public_html/test/prisijungimas.php on line 22


Gal galetumet padeti?

Parašė Noyz· 2011 Bir. 22 23:06:32
#7

1dEo parašė:
Sveiki, taigi susiduriau su beda. Bandziau bandziau ja isspresti ir visvien taspats

Stai kokia klaida:


Warning: mysql_num_rows(): supplied argument is not a valid <span style="border-bottom: 1px dotted black;">MySQL</span> result resource in /home/testavimas/domains/testavimas.us.lt/public_html/test/prisijungimas.php on line 22


Gal galetumet padeti?


Duok 22 eilutę.

Parašė 1dEo· 2011 Bir. 22 23:06:13
#8

Duodu visa if'a


if(mysql_num_rows($sql)==1){
session_register("myusername");
session_register("mypassword");
echo "<script type='text/javascript'>
<!--
window.location = 'login_success.php'
//-->
</script>";
}
else {
echo "Wrong Username or Password";
}

Parašė ĄČĘĖĮŠŲ· 2011 Bir. 23 00:06:27
#9

Bet čia net dviemetis tokias login "sistemas" sugebėtų nulaužt.

Parašė 1dEo· 2011 Bir. 23 00:06:07
#10

PGE, man neidomu dabar tavo lauzimai, man reikia issiaiskinti kodel Erroras.

Redagavo 1dEo· 2011 Bir. 23 00:06:10

Parašė Faitas.· 2011 Bir. 23 08:06:23
#11

Duok kintamojo $sql aprašymą :)

Parašė bruzgis· 2011 Bir. 23 09:06:36
#12

Faitas. parašė:
Sveikas. Aš dirbu su framework'u, todėl ir tau patarčiau tai išbandyti. Bet paaiškinsiu ir su PHP :)

Pirmiausia turėtum parašyti tvarkingą prisijungimo formą:

login.php


<html>
<head><title>Prisijungimas</title></head>
<body>
 
<form action='login_check.php' method='post'>
Vardas:<br />
<input type='text' name='username' maxlength='30'><br /><br />
Slaptažodis:<br />
<input type='password' name='password' maxlength='50'><br /><br />
<input type='submit' name='login' value='Prisijungti'>
</form>
 
</body>
</html>


PASTABA: Niekados nenaudok GET duomenims gauti :) Nes GET funkcija atvaizduoja gaunamus duomenis naršyklės URL'e

Toliau reikia failo, kuris tikrintų visus duomenis :)

login_check.php


<?php
 
//Gauname visus duomenis
$username = $_POST['username'];
$password = $_POST['password'];
 
//Tikriname ar lankytojas įvedė tikrai visus duomenis
$check = TRUE; // Tikrinimo kintamasis
$msg = ""; // Teksto (string) kintamasis, į kurį rašysime klaidas
 
if(!isset($username))
{
$check = FALSE; // Klaida? Nustatome check kintamąjam FALSE reikšme
$msg = $msg . "Jūs pamiršote įvesti vartotojo vardą<br />";
}
if(!isset($password))
{
$check = FALSE; // Klaida? Nustatome check kintamąjam FALSE reikšme
$msg = $msg . "Jūs pamiršote įvesti slaptažodį<br />";
}
 
//Tikriname ar viskas gerai
if($check == FALSE)
{
//Juk check kintamasis yra FALSE, tai reiškia, kad įvyko klaida.
echo $msg;
}
else
{
//Nustatome sesijos kintamuosius
$_SESSION['username'] = $username;
 
//Išvedame sakinį
echo "Sveikas, " . $_SESSION['username'];
}
 
?>


Na, dar keletas patarimų. :) Jei darysi duomenų gavimą iš duom.bazės, tai daryk su funkcijomis. Funkcijos veikia taip:


<?php
 
function pirmoji_funcija($kintamasis1, $kintamasis2)
{
$sum = $a + $b;
 
return $sum;
}
 
?>


$kintamasis1, $kintamasis2 yra nebūtini. :) Taip pat, return gražina reikšmę, šiuo atvėju būtų taip:


<?php
 
$a = 10;
$b = 55;
 
echo pirmoji_funcija($a, $b); // Mums išvestų $sum kintamojo reikšmę.
 
?>


Tai tiek šiam kartui. Sekmės kuriant.



Palikai klaidu :)



<?php
 
function pirmoji_funcija($kintamasis1, $kintamasis2)
{
$sum = $a + $b;
 
return $sum;
}
 
?>



Tai ir turetu but


<?php
 
function pirmoji_funcija($a, $b)
{
$sum = $a + $b;
 
return $sum;
}
 
?>



Dar patarimas.

$msg = $msg . "dar teksto";

Butu paprasciau ir greiciau $msg .= "Dar teksto";


;)
1dEo parašė:
Duodu visa if'a


if(mysql_num_rows($sql)==1){
session_register("myusername");
session_register("mypassword");
echo "<script type='text/javascript'>
<!--
window.location = 'login_success.php'
//-->
</script>";
}
else {
echo "Wrong Username or Password";
}



Taip negalima....

Slaptazodi privalai koduot (

md5($_POST['password'])
).

Su opera (nzn kaip su kitom narsyklem) galima atsidaryt sesijas ir perziuret ju duomenis, gal net ir pakeist pavyktu :)
1dEo parašė:
Duodu visa if'a


if(mysql_num_rows($sql)==1){
session_register("myusername");
session_register("mypassword");
echo "<script type='text/javascript'>
<!--
window.location = 'login_success.php'
//-->
</script>";
}
else {
echo "Wrong Username or Password";
}



persirasyk $SQL i

Redagavo bruzgis· 2011 Bir. 23 09:06:39

Parašė 1dEo· 2011 Bir. 23 09:06:49
#13

Tai taip ir nelabai supratau kame beda :DD. Man atrodo kaip tik su sesijom yra saugiau.

 
<?php
 
 
//Cia buvo mano prisijungimo duomenys,kuriu neuzkomentavau
 
 
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");
$myusername=$_POST['myusername'];
$mypassword=$_POST['mypassword'];
$myusername = stripslashes($myusername);
$mypassword = stripslashes($mypassword);
$myusername = mysql_real_escape_string($myusername);
$mypassword = mysql_real_escape_string($mypassword);
$sql="SELECT * FROM $tbl_name WHERE username='$myusername' and password='$mypassword'"; //$tbl_name yra lygus mano lenteles pavadinimui
$result=mysql_query($sql);
$count=mysql_num_rows($result);
if($count==1){
session_register("myusername");
session_register("mypassword");
header("location:login_success.php"); //cia dariau ir su header ir su <span style="border-bottom: 1px dotted black;">javascript</span>
}
else {
echo "Wrong Username or Password";
}
?>

Redagavo 1dEo· 2011 Bir. 23 10:06:17

Parašė Faitas.· 2011 Bir. 23 10:06:34
#14

chipass, ne, funkcijos kintamuosius gali aprašyti bet kaip :) Svarbu, kad būtų kintamieji. Jei tu taip darysi, tai žinai kiek tau funkcijų prireiks, jei norėsi padaryti 2 dalykus? :D Tad... :)

Parašė 1dEo· 2011 Bir. 23 11:06:55
#15

tai padesit kas nors isprest sia beda ? ...
Man dabar isviso nebemeta jokio Eror'o, taciau ismeta Wrong username or password nors duomenis tikrai gerus suvedu.

Redagavo 1dEo· 2011 Bir. 23 11:06:03

Parašė Faitas.· 2011 Bir. 23 11:06:28
#16

Spėju todėl meta, kad MYSQL duom.bazėje yra neužkoduotas slaptažodis o tu vedi ir dar koduoji, tad... :) Arba atvirkščiai. ;)

Parašė 1dEo· 2011 Bir. 23 11:06:01
#17

Nelabai supratau....Mysql tik duomenis yra .
kad username=kazkas
o pass=kazkas

Parašė Faitas.· 2011 Bir. 23 11:06:23
#18

O password'as skaičiais ir raidėmis, ar tavo įvestas matosi? :)

Parašė 1dEo· 2011 Bir. 23 11:06:10
#19

Mano ivestas matosi.

<?php
 
include "opendb.php";
 
$name=$_POST['name'];
$pass=$_POST['pass'];
 
 
 
$uzk=mysql_query("SELECT count(id) FROM prisijungimas WHERE name='$name' and pass='$pass'");
 
$result=mysql_result($uzk, 0);
 
if ($result!=1) echo "Prisijungimas nepavyko :(.";
 
else {
	echo "Prisijungimas pavyko :)!";
	$_SESSION['name']=$name;
};
 
?>


Sita pats katik parasiau ir visvien taspats :/. Niekaip nesuprantu kame beda.

Redagavo 1dEo· 2011 Bir. 23 11:06:05

Parašė Faitas.· 2011 Bir. 23 12:06:32
#20

Išviso, turėtum duomenis imti ne taip. :)

Pavyzdys:


<?php
 
//Gauname įvesta vartotojo vardą
$username = $_POST['username'];
 
//MySQL duom.bazėje yra lentelė vartotojai, lentelės turinys: id, username, password
 
//Ieškome tokio vartotojo, kuris buvo įvestas į formą
$query = mysql_query("SELECT * FROM vartotojai WHERE username = '$username' LIMIT 1");
 
if(mysql_num_rows($query) == 0)
{
echo "Toks vartotojas nerastas.";
}
else
{
$password = md5($_POST['password']);
 
while($row == mysql_fetch_array($query))
{
$user_password_db = $row['password']; // Turi duom.bazėje būti slaptažodis užkoduotas md5 koduote
 
if($password == $user_password_db)
{
$_SERVER['name'] = $username;
}
else
{
echo "Neteisingas slaptažodis";
}
}
}
 
?>

Parašė 1dEo· 2011 Bir. 23 13:06:02
#21

Man dabar toks var tk veikia dar veliau tavo pabandysiu, bet va dbr tik toks normaliai veikia


<html>
<head>
<title>Prisijungimas</title>
</head>
<body>
 
 
<form name='prisijungimas' action='index.php' method='post'>
<h3>Prisijungti</h3>
Vardas: <input type='text' name='user'>
<br>
Slaptazodis: <input type='password' name='slap'>
<br>
<input type='submit' value='Prisijungti'>
</form>
 
 
 
<?php
 
$user=$_POST['user'];
$slap=$_POST['slap'];
 
if (($user=="kazkas") && ($slap=="kazkas")) { 
echo "Prisijungimas pavyko :)!";
 
}
 
else { echo "Prisijungimas nepavyko :(.";
}
 
 
?>
</body>
</html>


BEt jis speju yra labai nesaugus.. :|

Parašė Faitas.· 2011 Bir. 23 13:06:12
#22

Net nebandyk tokių daryti... :)