Session leren gebruiken.

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Full stack developer Node.js, React Remote

Functie Als fullstack JavaScript developer vind jij het uitdagend om op basis van concrete klantvragen nieuwe functionaliteiten te ontwikkelen. Bij voorkeur worden deze functionaliteiten op een bepaalde manier geprogrammeerd, zodat ze door meerdere klanten te gebruiken zijn. Je hebt dus vaak te maken met abstracte vraagstukken. Om dit te kunnen realiseren sta je nauw in contact met de product owner en/of klant. Je bent niet alleen onderdeel van het development team, maar hebt ook vaak contact met de product-owner en/of klanten om daardoor inzichten te verzamelen die leiden tot productverbeteringen. • Inzichten verzamelen bij de klant en/of product owner •

Bekijk vacature »

NodeJS developer

Functie Als Fullstack developer kom je te werken in het ontwikkelteam. Je bent samen met je collega’s continu bezig om de software uit te breiden, maar hiernaast doe je onderzoek naar de inzet van nieuwe technieken, tools of bijvoorbeeld Machine Learning. Ze willen met hun software echt voorlopen op andere en toegevoegde waarde leveren voor de eindgebruiker. Mede hierom zijn ze erg benieuwd naar iemand zijn persoonlijkheid, of hij graag nieuwe dingen uitzoekt (Google!), en initiatief neemt. Qua technische kennis zoeken ze iemand die goed op de hoogte is van de nieuwste ontwikkelingen, daar zij nu ontwikkelen op NodeJs back-end,

Bekijk vacature »

Web Application Developer

Dit ga je doen Samen met het team werk je aan de visualisatie functionaliteiten en hoe dit gebruikt kan worden in een operationele setting; Het ontwerpen, ontwikkelen, onderhouden en leveren van support betreft het Warehouse Management Systeem en de bijbehorende web visualisaties; Je gebruikt hierbijde tools WebGL en ASP.net; Het meewerken in implementatieprojecten; Het leveren van Go-Live Support; Sparren met jouw Amerikaanse collega's. Hier ga je werken Voor een internationale organisatie in de transport zijn wij momenteel op zoek naar een Web Application Developer. Ze zijn wereldwijd de grootste speler en lopen voorop met het automatiseren van alle processen van

Bekijk vacature »

Senior front end developer Digital Agency Amsterda

Functie Wij werken in multidisciplinaire teams aan verschillende projecten, echter blijf je niet gebonden aan 1 team. Dit houdt in dat wij verschillende specialisten in dienst hebben en deze door middel van een roulatiesysteem in multidisciplinaire teams laten werken. Het team bestaat vaak uit Frontend developer(s), Backend Developer(s), Designer(s), Tester(s) en Mobile Developer(s). Deze teams worden afgewisseld waardoor jij de mogelijkheid krijgt om met iedereen een keer samen te werken. Als Frontend Developer ben jij ónze Specialist op dit gebied. Jij werkt mee aan verschillende projecten voor verschillende klanten. Denk bijvoorbeeld aan klanten, zoals’; BAM, IDFA en Ultimaker. Hierbij zorg

Bekijk vacature »

Backend developer

Functie omschrijving Ben jij graag bezig met de back-end van applicaties? Zou je dit graag willen doen voor een kleine werkgever waar ook tijd is voor een drankje op zijn tijd? Je taken hierbij zullen bestaan uit: Gebruik maken van de volgende technieken: .NET (core), C#, SQL, XML, MVC, JSON, REST & SOAP API. Gebruik maken van de volgende tools: Visual Studio, GIT, Jira, Jenkins. Bovengenoemde technieken en tools ga je gebruiken om: Nieuwe functionaliteiten te ontwikkelen. Wijzigingsverzoeken van klanten uitvoeren. Verzorgen van koppelingen tussen data. Bedrijfsprofiel Jouw nieuwe werkgever bevindt zich in regio Raamdonksveer en bieden oplossingen op gebied

Bekijk vacature »

Software Programmeur PHP - JAVA

Functie Wil jij bij een platte en informele organisatie werken? Lees dan snel verder! Voor een opdrachtgever in omgeving Rotterdam dat zich gespecialiseerd heeft in het realiseren van veilige netwerkverbindingen zijn wij op zoek naar een leuke software developer ter versterking van het huidige team. Hoe kan jouw dag er straks uitzien? Je gaat software en webapplicaties ontwikkelen met behulp van de talen PHP, JAVA en Node.js. Je gaat klanten ondersteunen op het gebied van geleverde software en webapplicaties. Je gaat technische klussen uitvoeren op locatie bij klanten. Je onderhoudt contact met de projectleider om er zeker van te zijn

Bekijk vacature »

Fullstack developer

Functie omschrijving Ben jij toe aan een nieuwe uitdaging en zou jij graag bij een platte maar informele organisatie werken? Voor een mooi softwarebedrijf in omgeving Alblasserdam zijn wij op zoek naar versterking op de afdeling Software Development! Als Fullstack react.js developer wordt je bij dit bedrijf onderdeel van de volledige ontwikkeling van requirement tot oplevering! Jouw focus ligt op de front end en alles wat daarbij komt kijken. Je gaat ontwerpen, ontwikkelen, testen en valideren. Je zult voornamelijk werken met React.js en Typescript. Maar ook Javascript, HTML en CSS komen aanbod. Daarnaast zal je ook regelmatig met de back

Bekijk vacature »

.NET developer

Functie Heb jij veel kennis van ASP.NET Webforms en wil jij juist de overstap maken naar ASP.NET Core? Wij zijn per direct op zoek naar een ervaren .NET Webdeveloper die met ons samen ons platform wilt herschrijven van ASP.NET Webforms naar ASP.NET Core. Voor jou de unieke kans om met ons samen te innoveren en kennis op te doen van de nieuwste technieken binnen de Microsoft Stack. Wij hebben een development team met 10 IT specialisten bestaande uit onder andere 4 backend .NET developers en twee front-end developers. Wij zijn continu bezig om ons als team en bedrijf te blijven

Bekijk vacature »

SQL ontwikkelaar

Functieomschrijving Voor een gave werkgever in regio Breda zijn wij per direct op zoek naar een SQL ontwikkelaar/ functioneel consultant. Hier wordt jij mede verantwoordelijk voor zowel de design en implementatie van SQL-databases als voor het verstaan van de processen van klanten naar het vertalen van deze processen naar IT-oplossingen. Jouw takenpakket komt als volgt uit te zien: Je test de ontwikkelde oplossingen om er zeker van te zijn dat deze voldoen aan de functionele specificaties en de behoeften van de organisatie; Je ontwerpt, ontwikkelt en implementeert SQL-databases om de data behoeften van de organisatie te ondersteunen; Je stelt op

Bekijk vacature »

Software Developer

Functie omschrijving Heb jij affiniteit met ICT en een WO diploma in de pocket? Dan ben je hier aan het juiste adres. Voor een opdrachtgever in Amsterdam zijn wij op zoek naar kandidaten die (enige) ervaring hebben met Java, Javascript, C of C++. Je zal door middel van trainingen worden opgeleid tot een volwaardige Software Developer. Er wordt tijdens de training natuurlijk veel aandacht besteedt aan de vaktechnische aspecten, maar er gaat ook veel aandacht uit naar jouw persoonlijke ontwikkeling. Bedrijfsprofiel Bij deze opdrachtgever in de omgeving van Amsterdam zoeken ze meerdere enthousiaste kandidaten die hun carrière willen starten met

Bekijk vacature »

Full Stack Developer

Dit ga je doen Ontwikkelen van Product Informatie Management (PIM) systemen; Werken aan zowel grotere als kleine projecten voor toonaangevende klanten binnen o.a. de retail; Verantwoordelijk voor de front-end werkzaamheden; Naast de front-end werk je ook aan de backend. Hier ga je werken Als Full Stack Developer komt je te werken binnen een vooruitstrevende organisatie die Product Informatie Management (PIM) systemen levert aan hun klanten. Hun klanten zijn toonaangevende bedrijven binnen o.a. de retail. De organisatie zit gevestigd in regio Zwolle en bestaat uit zo'n 35 medewerkers, waarvan 30 IT. Je komt te werken binnen één van de zelfsturende development

Bekijk vacature »

Applicatie ontwikkelaar

Functie omschrijving Zelfstandige applicatie ontwikkelaar gezocht voor familiair bedrijf in omgeving Barendrecht! Ben jij op zoek naar een nieuwe uitdaging en zoek jij een informele werkgever waar je zelfstandig kunt werken binnen een leuk IT team, lees dan snel verder want wie weet zijn wij op zoek naar jou! Binnen deze rol houdt jij je met het volgende bezig: Onderhouden en ontwikkelen van de IT systemen; Opzetten van Azure Cloud systemen, denk aan interfaces, hardware op de Cloud, webportalen of BI functies; Werken aan scripts binnen verschillende software applicaties, denk aan ERP en CAD; Ontwikkelen en implementeren van MS PowerApps

Bekijk vacature »

Embedded Software Developer

Functie omschrijving Voor een mooi softwarebedrijf in omgeving Moordrecht zijn wij op zoek naar een Embedded Software developer. Ben jij enthousiast en een echte team player? Lees dan snel of dit iets voor jou is! Binnen deze rol houdt jij je bezig met alle werkzaamheden die nodig zijn om een functionaliteit te bouwen. Denk aan ontwerpen, architectuur, programmeren en algoritmes. Je voert test en validatie werkzaamheden uit bij de implementatie bij de klant. Ben jij een Embedded Software Developer die affiniteit heeft met de allernieuwste technieken? Laat dan snel wat van je horen! Bedrijfsprofiel Onze opdrachtgever bestaat uit een groot

Bekijk vacature »

Python developer Consultancy

Functie Als Python developer bij deze organisatie werk je voor verschillende klanten. Doordat de oprichter een groot netwerk heeft kun je zelf voorkeuren uitspreken in het type projecten dat je wilt gaan doen. Zo zijn er bijvoorbeeld langdurige of juist korte projecten, maar is ook het type klant, of project bespreekbaar. Werk jij bijvoorbeeld graag aan een nieuw, state-of-the-art web portaal of ben je liever betrokken bij een migratietraject van een bestaande applicatie? Wij gaan voor jou aan de slag! Eisen • Je bent een gedreven developer met sterke voorkeur voor Python • Je bent meer dan een codeklopper •

Bekijk vacature »

Software Ontwikkelaar

Functie omschrijving Voor een echt familiebedrijf in de omgeving van 's-Hertogenbosch ben ik op zoek naar een Software Developer. Jij gaat in de functie van Software Developer werken met C# en .NET framework Jij gaat maatwerk software ontwikkelen en softwareoplossingen creëren. Daarnaast optimaliseer je de bestaande software. Oplossingen waar de klant echt iets aan heeft, jij krijgt er energie van op dit te realiseren. Je gaat werken in een Microsoft omgeving(ASP.NET) en gebruikt daarnaast C# en MVC. Samen met het huidige IT team binnen deze organisatie verwerk je de wensen van de klant tot een (eind)product. Bedrijfsprofiel Deze organisatie is

Bekijk vacature »
Mark van den Brink

Mark van den Brink

17/09/2012 21:12:46
Quote Anchor link
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..

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<?
    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??
 
PHP hulp

PHP hulp

19/12/2024 14:46:33
 
Eddy E

Eddy E

17/09/2012 21:14:44
Quote Anchor link
Je code heeft echt 0,0 te maken met sessies.
Kijk eens op php.net en typ in het zoekvak eens gewoon "Session" in.
 
Wouter J

Wouter J

17/09/2012 21:25:15
Quote Anchor link
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:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
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 session_start:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
A.php
=====
<?php
session_start();

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


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

echo $_SESSION['x'];
?>


En klaar zijn we!




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 mysql_error en niet via een sessie
- check of een mail is verzonden
- gebruik de juiste mailheaders
- session_register is deprecated, sinds PHP4.1 (!!). Gebruik de syntax die ik je hierboven leerde (de $_SESSION array)
- exit of die 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.
 
Mark van den Brink

Mark van den Brink

18/09/2012 09:01:46
Quote Anchor link
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...

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?
    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.

Toevoeging op 18/09/2012 09:17:30:

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!
Gewijzigd op 18/09/2012 09:38:14 door Mark van den Brink
 
- Ariën  -
Beheerder

- Ariën -

18/09/2012 09:34:44
Quote Anchor link
session_register() weghalen..
Gebruik gewoon:

$_SESSION['dberror'] = $dberror;

Waarom je een sessie aanmaakt voor een databasefoutmelding ontgaat mij even.
Gewijzigd op 18/09/2012 09:37:11 door - Ariën -
 
Mark van den Brink

Mark van den Brink

18/09/2012 09:45:00
Quote Anchor link
Het is een krijgertje..

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

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<?

                // 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...
 
- Ariën  -
Beheerder

- Ariën -

18/09/2012 09:46:52
Quote Anchor link
Voor een databasefoutmelding heb je toch geen sessies nodig?
 
Mark van den Brink

Mark van den Brink

18/09/2012 10:14:21
Quote Anchor link
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...
 
- Ariën  -
Beheerder

- Ariën -

18/09/2012 10:16:51
Quote Anchor link
Er zit gewoon foutafhandeling in.
 
Mark van den Brink

Mark van den Brink

18/09/2012 10:23:11
Quote Anchor link
Dan hou ik hem lekker zo.'

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

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?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:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
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..

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
if (!mysql_connect($host, $user, $pass)) {
    if (!mysql_select_db($dbname)){


Toevoeging op 18/09/2012 11:07:19:

Laat het ontvangen van mails maar zitten ontvang zojuist 20 mails in 1x
Gewijzigd op 18/09/2012 13:24:21 door Mark van den Brink
 
Albert de Wit

Albert de Wit

18/09/2012 11:45:16
Quote Anchor link
je bent vergeten je database login gegevens te veranderen...
 
Mark van den Brink

Mark van den Brink

18/09/2012 13:24:55
Quote Anchor link
Dat was inderdaad niet handig bedankt!

Meteen alles maar wijzigen haha!
 
Nick Dijkstra

Nick Dijkstra

18/09/2012 13:40:13
Quote Anchor link
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
<?php
if (!mysql_connect($host, $user, $pass)) {
    if (!mysql_select_db($dbname)){
?>

Als het connecten niet lukt dan met de db verbinding maken?

Ik denk dat je het zo bedoelt:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
<?php
if (mysql_connect($host, $user, $pass)) {
    if (mysql_select_db($dbname)){

    }
else{
        echo 'Kan niet verbinden met de database';
    }
}
else{
    echo 'Kan geen verbinding maken met de server';
}

?>
 
Mark van den Brink

Mark van den Brink

18/09/2012 14:21:10
Quote Anchor link
Werkt! Helemaal super!
 
Wouter J

Wouter J

18/09/2012 15:19:32
Quote Anchor link
En je weet ook wat het doet?

Want op mysql_connect php.net kun je onder Return Values lezen wat de functie teruggeeft. In dit geval:
Quote:
Returns a MySQL link identifier on success or FALSE on failure.

Als er een fout is zien we dus dat er FALSE teruggegeven wordt. Daarop kunnen we dus checken, is er iets anders dan false teruggegeven dan kun je gewoon doorgaan.
De functie mysql_error bevat de error die omschrijft wat er fout is gegaan, toon deze niet aan je bezoekers, maar als je hem lokaal debugd is dit natuurlijk erg handig.
 
Mark van den Brink

Mark van den Brink

19/09/2012 18:37:34
Quote Anchor link
Oke duidelijk dus eigenlijk wat jij zegt is het nog het beste om er een mysql_error aan toe te voegen:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<?php
if (mysql_connect($host, $user, $pass)) {
    if (mysql_select_db($dbname)){

    }
else{
        echo 'Kan niet verbinden met de database<br>';
        echo mysql_error(). "<br>\n";

    }
}
else{
    echo 'Kan geen verbinding maken met de server<br>';
    echo mysql_error(). "<br>\n";
}

?>


is dat de dan de beste manier? Aangezien ik vooral op de site lees dat or die nooit meer gebruikt mag worden zoals bijv:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
mysql_connect($host, $user, $pass)or die(mysql_error());


of zal ik hem zo laten zoals Nick aangaf??
 
Wouter J

Wouter J

19/09/2012 18:52:57
Quote Anchor link
Als je het script aan het maken bent, wat we de development fase/omgeving noemen, wil je natuurlijk zo veel mogelijk informatie zien om je fout zo snel mogelijk op te lossen.

Als de website online staat, wat we de production fase/omgeving noemen, wil je juist zo min mogelijk informatie tonen. Het maakt de gebruiker niet uit wat er fout gaat, alleen of er wat fout gaat. Tevens bevatten de foutmeldingen vaak gegevens zoals inlog gegevens of gegevens over hoe de tabellen en velden heten. Dit is natuurlijk heel handige informatie voor een hacker en dus is het gevaarlijk deze errors te tonen.

Wat je het beste kunt doen is in de production omgeving de error loggen in een bestand en in de development omgeving zoveel mogelijk tonen. Een voorbeeldje hoe ik het zal doen kun je vinden in SQL boilerplate, de link die ik je al eens eerder had gegeven.
 
Mark van den Brink

Mark van den Brink

19/09/2012 19:11:32
Quote Anchor link
Ik ga daar even rustig voor zitten daar zit duidelijk een hoop informatie waar ik verder mee kan.

Bedankt alvast nu eerst even brilletje op en gaan lezen maar.
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.