Ik zie dat veel mensen gebruik maken van sessies en merk dat dit
erg handig in gebruik is voor een hoop dingen.

Graag zou ik meer willen weten over het gebruik van sessies weet iemand een site waar ik dit kan leren of kan iemand mij vertellen waar sessie eigenlijk goed voor zijn!

Zo gebruik ik bijv. al jaren de volgende script om mijn database te connecten (heb ik van een vriend gehad) Maar heb eigenlijk geen idee hoe het werkt..


<?
    session_start();

                // database configuratie
                $dbname = "database_naam"; // database naam
                $user = "mysql_username"; // gebruikersnaam van mysql
                $pass = "mysql_password"; // wachtwoord van mysql
                $host = "localhost"; // host naar mysql

                // user configuratie
                $to = "[email protected]"; // jou email adres
                $subject = "Database Connectie Mislukt"; // onderwerp van de email
                $from = "From: Mark <[email protected]";

    if (!mysql_select_db($dbname, mysql_connect($host, $user, $pass)))
    {
        if (!$_SESSION["dberror"])
        {
            $msg = "============================================\n";
            $msg .= "Database connectie mislukt!\n";
            $msg .= "============================================\n\n";
            
            $msg .= "De connectie met de database is mislukt!\n\n";
            
            $msg .= "Datum: " . date("d.m.Y") . "\n";
            $msg .= "Tijd: " . date("H:i") . "\n";
            $msg .= "Ip addr: " . $_SERVER['REMOTE_ADDR'] . "\n\n";
            
            $msg .= "Mark\n";
            
            mail($to, $subject, $msg, $from);
            
            $dberror = 1;
            session_register(dberror);
        }
        
        echo "
        <html>
        <head>
        <title>Database connectie mislukt</title>
        </head>
        
        <body>
        
        <h1>De connectie met de database is mislukt.</h1>
        
        <p>Probeer het over enkele minuten opnieuw. Blijf niet de pagina herladen (refreshen). 
        Wanneer u dit wel doet wordt de database alleen nog maar meer belast. Er is een 
        e-mail gestuurd naar &eacute;&eacute;n van de administrators.</p>
        
        <p>Onze excuses en bedankt voor het begrip.</p>
        
        <p><i>Mark</i></p>
        
        </body>
        </html>";
        
        exit();
    }
?>


Kan iemand mij iets vertellen of verwijzen naar een goeie tutorial hier over??
Je code heeft echt 0,0 te maken met sessies.
Kijk eens op php.net en typ in het zoekvak eens gewoon "Session" in.
Het probleem
Algemeen: Ik heb een variabele X die ik op pagina A aanmaak. Vervolgens wil ik die gebruiken op pagina B, maar niet via de URL (en GET parameters).
Toepassing: Dit heb je bijv. in een inlog script, je wilt een variabele in het inlog gedeelte setten met de waarde: ingelogd. Vervolgens wil je op elke pagina kunnen kijken of hij is ingelogd. [sidenote]Het maken van een inlog systeem is ingewikkelder, omdat je moet kijken of je nog steeds met dezelfde persoon te maken hebt[/sidenote]

Een idee
Je kan het niet met gewone variabele doen:
A.php
=====
<?php
$x = 'foobar';
?>

B.php
=====
<?php
echo $x;
?>


En via een database is veel te veel overhead.

De oplossing
De oplossing is, zoals je wel verwachte, sessies (of cookies) gebruiken. Het verschil daar tussen is simpel. Eigenlijk bestaan er alleen cookies, deze sla je op in één van de TEMP dirs van het browser. Die blijven beschikbaar tot ze verlopen zijn, dit kan oplopen in de jaren.
PHP heeft de sessies er bovenop bedacht. De waarde van een sessie wordt vastgehouden door PHP en de id van de sessie wordt opgeslagen als een cookie, zo weet PHP welke sessie bij deze bezoeker hoort. Zodra je je browser sluit zal de cookie verwijderd worden.

Hoe stel ik een sessie variabele in?
Om te kunnen werken met een sessie moet elke pagina die sessies wilt gebruiken beginnen met [php]session_start[/php]:
A.php
=====
<?php
session_start();

$x = 'foobar';
?>

B.php
=====
<?php
session_start();

echo $x;
?>


Alle sessies sla je op in de super global $_SESSION, wat een array is. In ons geval:
A.php
=====
<?php
session_start();

$_SESSION['x'] = 'foobar';
?>

B.php
=====
<?php
session_start();

echo $_SESSION['x'];
?>


En klaar zijn we!

[hr]

Dat script van je vriend is verre van goed:
- Verander de 1e if in 2 if statements, waarbij je bij de eerste de connectie en bij de 2e select db controleert
- krijg de errors via de functie [php]mysql_error[/php] en niet via een sessie
- check of een mail is verzonden
- gebruik de juiste mailheaders
- [php]session_register[/php] is deprecated, sinds PHP4.1 (!!). Gebruik de syntax die ik je hierboven leerde (de $_SESSION array)
- [php]exit[/php] of [php]die[/php] gebruikt je zelden en is in dit geval onnodig
- echo nooit hele stukken PHP. Sluit je PHP, plaats de HTML en open daarna je PHP weer.
Dat is nog eens een uitleg waar ik wat aan heb en inderdaad erg handig om dingen te gebruiken en veiliger maar eens kijken of ik dit script nu goed kan krijgen...


<?
    session_start();

                // database configuratie
                $dbname = "database_naam"; // database naam
                $user = "mysql_username"; // gebruikersnaam van mysql
                $pass = "mysql_password"; // wachtwoord van mysql
                $host = "localhost"; // host naar mysql

                // user configuratie
                $to = "[email protected]"; // jou email adres
                $subject = "Database Connectie Mislukt"; // onderwerp van de email
                $website_naam = 'Mijn Site';
                $eigen_emailadres = 'mijn_emailadres@mijn_domein.nl';
                $error_emailadres = 'mijn_emailadres@mijn_domein.nl';
                $naam_verzender = 'Afzender';
                $email_verzender = 'emailadres_van_verzender@zijn_domein.nl';
                $html = true;
                
$headers	 = 'From: ' . $website_naam . ' <' . $eigen_emailadres . '>' . PHP_EOL;
$headers	.= 'Reply-To: ' . $naam_verzender . ' <' . $email_verzender . '>' . PHP_EOL;
$headers	.= 'Return-Path: Mail-Error <' . $error_emailadres . '>' . PHP_EOL;
$headers	.= 'X-Mailer: PHP/' . phpversion() . PHP_EOL;
$headers	.= 'X-Priority: Normal' . PHP_EOL;
$headers	.= ($html) ? 'MIME-Version: 1.0' . PHP_EOL : '';
$headers	.= ($html) ? 'Content-type: text/html; charset=iso-8859-1' . PHP_EOL : '';

if (!mysql_connect($host, $user, $pass)) {
    if (!mysql_select_db($dbname)){
    {
        if (!$_SESSION["dberror"])
        {
            $msg = "============================================\n";
            $msg .= "Database connectie mislukt!\n";
            $msg .= "============================================\n\n";
            
            $msg .= "De connectie met de database is mislukt!\n\n";
            
            $msg .= "Datum: " . date("d.m.Y") . "\n";
            $msg .= "Tijd: " . date("H:i") . "\n";
            $msg .= "Ip addr: " . $_SERVER['REMOTE_ADDR'] . "\n\n";
            
            $msg .= "Mark\n";
            
            if (mail($to, $subject, $msg, $headers)) {
    echo 'Error mail is verzonden.'; 
} 
else { 
    echo 'Error mail niet verzonden.'; 
}
            $dberror = 1;
            session_register(dberror);
        }
        
?>
        <html>
        <head>
        <title>Database connectie mislukt</title>
        </head>
        
        <body>
        
        <h1>De connectie met de database is mislukt.</h1>
        
        <p>Probeer het over enkele minuten opnieuw. Blijf niet de pagina herladen (refreshen). 
        Wanneer u dit wel doet wordt de database alleen nog maar meer belast. Er is een 
        e-mail gestuurd naar &eacute;&eacute;n van de administrators.</p>
        
        <p>Onze excuses en bedankt voor het begrip.</p>
        
        <p><i>Mark</i></p>
        
        </body>
        </html>";
        
<?php
    }
?>

Ik begrijp je uitleg maar ik weet nog niet hoe mijn script er dan uit hoort te zien.

[size=xsmall]Toevoeging op 18/09/2012 09:17:30:[/size]

Ik weet alleen niet hoe ik het volgende goed moet aanpassen..

- session_register is deprecated, sinds PHP4.1 (!!). Gebruik de syntax die ik je hierboven leerde (de $_SESSION array)

Snap wel wat je bedoelt maar weet niet zo goed hoe ik hem moet invoegen in dit script.

Is hij voor de rest wel goed? Of heb ik hem nu nog erger gemaakt haha!
session_register() weghalen..
Gebruik gewoon:

$_SESSION['dberror'] = $dberror;

Waarom je een sessie aanmaakt voor een databasefoutmelding ontgaat mij even.
Het is een krijgertje..

Maar hoe zou jij het doen dan gebruik van sessies weg en dan zoiets?


<?

                // database configuratie
                $dbname = "database_naam"; // database naam
                $user = "mysql_username"; // gebruikersnaam van mysql
                $pass = "mysql_password"; // wachtwoord van mysql
                $host = "localhost"; // host naar mysql

                // user configuratie
                $to = "[email protected]"; // jou email adres
                $subject = "Database Connectie Mislukt"; // onderwerp van de email
                $website_naam = 'Mijn Site';
                $eigen_emailadres = 'mijn_emailadres@mijn_domein.nl';
                $error_emailadres = 'mijn_emailadres@mijn_domein.nl';
                $naam_verzender = 'Afzender';
                $email_verzender = 'emailadres_van_verzender@zijn_domein.nl';
                $html = true;
                
$headers     = 'From: ' . $website_naam . ' <' . $eigen_emailadres . '>' . PHP_EOL;
$headers    .= 'Reply-To: ' . $naam_verzender . ' <' . $email_verzender . '>' . PHP_EOL;
$headers    .= 'Return-Path: Mail-Error <' . $error_emailadres . '>' . PHP_EOL;
$headers    .= 'X-Mailer: PHP/' . phpversion() . PHP_EOL;
$headers    .= 'X-Priority: Normal' . PHP_EOL;
$headers    .= ($html) ? 'MIME-Version: 1.0' . PHP_EOL : '';
$headers    .= ($html) ? 'Content-type: text/html; charset=iso-8859-1' . PHP_EOL : '';

if (!mysql_connect($host, $user, $pass)) {
    if (!mysql_select_db($dbname)){

            $msg = "============================================\n";
            $msg .= "Database connectie mislukt!\n";
            $msg .= "============================================\n\n";
            
            $msg .= "De connectie met de database is mislukt!\n\n";
            
            $msg .= "Datum: " . date("d.m.Y") . "\n";
            $msg .= "Tijd: " . date("H:i") . "\n";
            $msg .= "Ip addr: " . $_SERVER['REMOTE_ADDR'] . "\n\n";
            
            $msg .= "Mark\n";
            
            if (mail($to, $subject, $msg, $headers)) {
    echo 'Error mail is verzonden.'; 
} 
else { 
    echo 'Error mail niet verzonden.'; 
}
        }
        
?>
        <html>
        <head>
        <title>Database connectie mislukt</title>
        </head>
        
        <body>
        
        <h1>De connectie met de database is mislukt.</h1>
        
        <p>Probeer het over enkele minuten opnieuw. Blijf niet de pagina herladen (refreshen). 
        Wanneer u dit wel doet wordt de database alleen nog maar meer belast. Er is een 
        e-mail gestuurd naar &eacute;&eacute;n van de administrators.</p>
        
        <p>Onze excuses en bedankt voor het begrip.</p>
        
        <p><i>Mark</i></p>
        
        </body>
        </html>";
        
<?php
    }
?>


Correct me if i'm wrong...
Voor een databasefoutmelding heb je toch geen sessies nodig?
Daar heb je gelijk in maar heb het gekregen en eigenlijk nooit veranderd.

Hoe is het script boven zonder sessies moet alleen nog foutafhandeling in denk ik...
Er zit gewoon foutafhandeling in.
Dan hou ik hem lekker zo.'

Alleen heb nu aantal foutjes ondekt waar ik niet uitkom..


<?php

                // database configuratie
                $dbname = "---"; // database naam
                $user = "---"; // gebruikersnaam van mysql
                $pass = "---"; // wachtwoord van mysql
                $host = "localhost"; // host naar mysql

                // user configuratie
                $to = "[email protected]"; // jou email adres
                $subject = "Database Connectie Mislukt"; // onderwerp van de email
                $website_naam = 'Sonic GFX :: Designs';
                $eigen_emailadres = '[email protected]';
                $error_emailadres = '[email protected]';
                $naam_verzender = 'Sonic GFX';
                $email_verzender = '[email protected]';
                $html = true;
                
$headers     = 'From: ' . $website_naam . ' <' . $eigen_emailadres . '>' . PHP_EOL;
$headers    .= 'Reply-To: ' . $naam_verzender . ' <' . $email_verzender . '>' . PHP_EOL;
$headers    .= 'Return-Path: Mail-Error <' . $error_emailadres . '>' . PHP_EOL;
$headers    .= 'X-Mailer: PHP/' . phpversion() . PHP_EOL;
$headers    .= 'X-Priority: Normal' . PHP_EOL;
$headers    .= ($html) ? 'MIME-Version: 1.0' . PHP_EOL : '';
$headers    .= ($html) ? 'Content-type: text/html; charset=iso-8859-1' . PHP_EOL : '';

if (!mysql_select_db($dbname, mysql_connect($host, $user, $pass)))
    {
   

            $msg = "============================================\n";
            $msg .= "Database connectie mislukt!\n\r";
            $msg .= "============================================\n\n";
            
            $msg .= "De connectie met de database is mislukt!\n\n";
            
            $msg .= "Datum: " . date("d.m.Y") . "\n";
            $msg .= "Tijd: " . date("H:i") . "\n";
            $msg .= "Ip addr: " . $_SERVER['REMOTE_ADDR'] . "\n\n";
            
            $msg .= "Mark\n";
            
            if (mail($to, $subject, $msg, $headers)) {
    echo 'Error mail is verzonden.'; 
} 
else { 
    echo 'Error mail niet verzonden.'; 
}
        
?>
        <html>
        <head>
        <title>Database connectie mislukt</title>
        </head>
        
        <body>
        
        <h1>De connectie met de database is mislukt.</h1>
        
        <p>Probeer het over enkele minuten opnieuw. Blijf niet de pagina herladen (refreshen). 
        Wanneer u dit wel doet wordt de database alleen nog maar meer belast. Er is een 
        e-mail gestuurd naar &eacute;&eacute;n van de administrators.</p>
        
        <p>Onze excuses en bedankt voor het begrip.</p>
        
        <p><i>Mark</i></p>
        
        </body>
        </html>";
        
<?php
    }
?>
  


Hij verstuurd ene mail maar de ene keer krijg ik hem wel en de andere keer krijg ik hem niet hoe kan dat?

en ik heb deze weer terug veranderd in:

 if (!mysql_select_db($dbname, mysql_connect($host, $user, $pass)))
    {


als ik 2 if statements gebruikte zei hij geen DB geselecteerd of heb ik hem verkeerd gescript..

if (!mysql_connect($host, $user, $pass)) {
    if (!mysql_select_db($dbname)){


[size=xsmall]Toevoeging op 18/09/2012 11:07:19:[/size]

Laat het ontvangen van mails maar zitten ontvang zojuist 20 mails in 1x
je bent vergeten je database login gegevens te veranderen...

Reageren