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šė 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 (
).
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... :)