Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2009-09-01 13:32:11

  debbie - Użytkownik

debbie
Użytkownik
Zarejestrowany: 2006-09-19

Skrypt logowania + php + dla wszystkich skryptów

Witam! Mam taki problem - mam skrypt logowania wygląda on tak:

Kod:

<?php
session_start();
mysql_connect("localhost","user","pass");
mysql_select_db("base");

if(isset($_SESSION['zalogowany'])) {
echo "Witam, ".$_SESSION['login'];
}else{

if(isset($_POST['wyslij'])) {


   if(mysql_num_rows(mysql_query("SELECT login, haslo
   FROM konta WHERE login = '".$_POST['login']."'
   && haslo = '".$_POST['haslo']."' ")) > 0) {


       if(mysql_num_rows(mysql_query("SELECT nr FROM konta
       WHERE login = '".$_POST['login']."'
       && haslo = '".$_POST['haslo']."' ")) > 0 ) {


           $_SESSION['zalogowany'] = true;
           $_SESSION['login'] = $_POST['login'];
           $_SESSION['haslo'] = $_POST['haslo'];
           echo "Jesteś zalogowany.";


       } else {

   echo "Złe hasło, proszę spróbować ponownie";
}
} else {
   echo "Nie ma takiego użytkownika";
}
} else {

?>
<form method='POST' action='logowanie.php'>
<b>nazwa uzytkownika:</b> <input type='text' name='login'><br>
<b>haslo:</b> <input type='password' name='haslo'><br>
<input type='submit' value='Wyślij' name='wyslij'>
</form>

<?php
}
}
?>

Jak widać działa na bazie mysql'a
Tylko tak - mam serwer apache na którym działają strony i podstrony. I chciałem zrobić tak aby dopiero po zalogowaniu
użytkownik miał do nich dostęp.  Czyli jak go przerobić aby np user po wpisaniu jakiejś podstrony obojętnie której ( oczywiście z tych które
zamieściłem na swoim serwerze apache) mógł z niej korzystać dopiero po zalogowaniu.
Był bym wdzięczny za pomoc.


debbie
[color=blue]Wrócę jak zjem zupę i drugie danie - tyle[/color]
[color=blue]a oto ta zupa:[/color]

Offline

 

#2  2009-09-01 14:01:33

  kamikaze - Administrator

kamikaze
Administrator
Zarejestrowany: 2004-04-16

Re: Skrypt logowania + php + dla wszystkich skryptów

Na każdej podstronie sprawdzaj czy  $_SESSION['zalogowany'] == true, jesli nie przekieruj na sronę logowania albo co tam chcesz.

Offline

 

#3  2009-09-01 15:07:07

  Wieloryb - Użytkownik

Wieloryb
Użytkownik
Zarejestrowany: 2009-06-20

Re: Skrypt logowania + php + dla wszystkich skryptów

Po co Ci haslo uzytkownika w sesji i 2 zapytania do bazy danych?


[img]http://www.debian.org/logos/button-mini.png[/img] [img]http://img142.imageshack.us/img142/4871/facebookk.gif[/img]

Offline

 

#4  2009-09-02 17:34:41

  jezoo - Dzięcioł

jezoo
Dzięcioł
Skąd: Z lasu
Zarejestrowany: 2005-09-02

Re: Skrypt logowania + php + dla wszystkich skryptów

mozesz tez tak to zrobic (wersja do rozbudowy), wez pod uwage tworzenie tpl;ow

Kod:

<?php
session_start();
ob_start();

function checkUser($login){
    $sql = "SELECT COUNT(*) FROM tabela WHERE login='$login'";
    $sql = mysql_query($sql);
    $sql = mysql_fetch_array($sql);
    
    if($sql[0] == 1)
        return true;
    else
        return false;
}

function authenticate($login,$pass){
    $sql = "SELECT COUNT(*) FROM tabela WHERE login='$login' AND passwd='$pass'";
    $sql = mysql_query($sql);
    $sql = mysql_fetch_array($sql);
    if($sql[0] == 1){
        $_SESSION['zalogowany'] = true;
        $_SESSION['login'] = $login;
        header('Location: ./');
    }else
        header('Location: ./');
}


if(checkUser($login)==true && isset($_SESSION['zalogowany'])){
    switch ($_REQUEST['url']){
        case "podstrona1":
            include('podstrona1.phtml');
        break;
        
        default:
            echo "Witaj wodzu!";
        break;
    }
    
} elseif($_REQUEST['akcja']=='logowanie'){
    authenticate($login,$pass);
}
else{
// formularz logowania
}
?>

[img]http://intershock.pl/images/icons/freebsd.jpg[/img] [img]http://www.the-eleven.com/site_media/static/img/postgresql_powered.png[/img] [img]http://www.wwgmc.com/images/badge_php.gif[/img]
LRU #480459

Offline

 

#5  2009-09-03 08:43:20

  kamikaze - Administrator

kamikaze
Administrator
Zarejestrowany: 2004-04-16

Re: Skrypt logowania + php + dla wszystkich skryptów

Imho checkUser() jest zbędna. I po co ob_start()?

Offline

 

#6  2009-09-11 22:15:39

  jezoo - Dzięcioł

jezoo
Dzięcioł
Skąd: Z lasu
Zarejestrowany: 2005-09-02

Re: Skrypt logowania + php + dla wszystkich skryptów

kamikaze, nie do konca, jezeli masz do sprawdzenia usera a login lub id jest w sesji zaszyte to mozesz kontrolowac w if;ie, a co do ob_start() bufor i naglowki, przydatna rzecz, jezeli ktos nie chce to nie musi uruchamiac.kiedys mialem problem z sesjami i to mi pomoglo


[img]http://intershock.pl/images/icons/freebsd.jpg[/img] [img]http://www.the-eleven.com/site_media/static/img/postgresql_powered.png[/img] [img]http://www.wwgmc.com/images/badge_php.gif[/img]
LRU #480459

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
To nie jest tylko forum, to nasza mała ojczyzna ;-)

[ Generated in 0.008 seconds, 11 queries executed ]

Informacje debugowania

Time (s) Query
0.00011 SET CHARSET latin2
0.00004 SET NAMES latin2
0.00137 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='18.222.166.127' WHERE u.id=1
0.00116 REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '18.222.166.127', 1732537793)
0.00057 SELECT * FROM punbb_online WHERE logged<1732537493
0.00045 SELECT topic_id FROM punbb_posts WHERE id=127003
0.00005 SELECT id FROM punbb_posts WHERE topic_id=14903 ORDER BY posted
0.00057 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=14903 AND t.moved_to IS NULL
0.00006 SELECT search_for, replace_with FROM punbb_censoring
0.00087 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=14903 ORDER BY p.id LIMIT 0,25
0.00102 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=14903
Total query time: 0.00627 s