[OOP] Gastenboek

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Traineeship IT regio Amsterdam/Utrecht

Wat ga je doen? Het traineeship begint met een fulltime maand cursussen en praktijkdagen, waarin je de basis van het IT-vak leert op de Shared Servicedesk (SSD). Daarnaast ga je meteen aan de slag voor je eerste certificering! (ITILv4). Je start in een groep met 4 tot 10 deelnemers, waarmee jij gedurende die maand optrekt en je kennis kunt delen. Na het voltooien van de eerste maand ga je direct voor een langere periode aan de slag bij één van onze klanten of blijf je intern bij ons op de Shared Servicedesk. Je bent het eerste aanspreekpunt van de eindgebruikers

Bekijk vacature »

Cloud Developer

Cloud Developers opgelet! Bij Luminis zijn ze opzoek naar jou. Lees de vacature en solliciteer direct. Luminis is een software- en technologiebedrijf met meerdere vestigingen. Vanuit deze vestigingen werken 200 professionals aan technisch hoogwaardige oplossingen voor klanten zoals KLM, Nike en Bol.com. Ook ontwikkelt Luminis eigen oplossingen op het gebied van cloud, Internet of Things, data intelligence, e-sports en e-learning. Luminis onderscheidt zich door aantoonbaar voorop te lopen in technologie en innovatie. Luminis heeft drie kernpunten die verankerd zitten in alles wat we doen: het omarmen van nieuwe technologie, meesterschap en kennis delen. Functiebeschrijving First things first! Het is belangrijk

Bekijk vacature »

Oracle APEX developer

Wat je gaat doen: Als Oracle APEX ontwikkelaar bij DPA werk je samen met collega’s aan de meest interessante opdrachten. Je zult je ervaring met SQL, PL/SQL, JavaScript, HTML en CSS inzetten om wensen van opdrachtgevers te vertalen naar technische oplossingen. Je werk is heel afwisselend, omdat DPA zich niet beperkt tot een specifieke branche. Zo ben je de ene keer bezig binnen de zorgsector, de andere keer is dit bij de overheid. Wat we vragen: Klinkt goed? Voor deze functie breng je het volgende mee: Je hebt een hbo- of universitaire opleiding afgerond Je hebt 2 tot 5 jaar

Bekijk vacature »

Front-End Developer

Als Front-End Developer bij Coolblue verbeter je de gebruiksvriendelijkheid van onze webshop voor miljoenen klanten. Wat doe je als Front-End Developer bij Coolblue? Als Front-end Developer werk je aan de gebruiksvriendelijkheid van onze webshop voor miljoenen klanten. Je vindt het leuk om samen te werken met de UX designer om stories op te pakken. Je krijgt energie van het bedenken van creatieve oplossingen en presenteert dit graag binnen het team. Daarnaast ben je trots op je werk en verwelkomt alle feedback. Ook Front-end Developer worden bij Coolblue? Lees hieronder of het bij je past. Dit vind je leuk om te

Bekijk vacature »

Belastingdienst - Freelance Senior Applicatie ontw

Startdatum: 01.06.2023 Richttarief: €65,00 - €75,00 Duur van de opdracht: 6 maanden Uren per week: 36 Taal: Nederlands vereist! Gelieve in het Nederlands te solliciteren. Functieomschrijving: We verwachten van je, dat je: Brede ervaring hebt als JAVA-ontwikkelaar; Ervaring hebt met Agile/Scrum-werken en je thuis voelt in een Agile omgeving; Een aandeel levert aan het scrumproces en in de SAFe-releasetrain; Zelfstandig werkt in een scrumteam en intensief de samenwerking op zoekt met je directe collega’s en je omgeving; Ervaring meebrengt met het schattten en inplannen van taken tot en met het testen en demonstreren van de opgeleverde functionaliteit; Collega’s in je

Bekijk vacature »

Traineeship Front-end developer (WO, 0 tot 3 jaar

Functie Zoals beschreven ga je vanaf start aan de slag bij een passende opdrachtgever, hierbij kijken ze echt naar jouw wensen, kennis/ervaring maar ook de reisafstand. Momenteel hebben ze meerdere klanten waarbij ze groepen hebben opgezet wat maakt dat er diverse uitdagende kansen liggen. Naast het werken bij de opdrachtgever, en het volgen van de masterclasses, zul je regelmatig met de andere trainees in contact zijn. Niet alleen op professioneel vlak maar juist ook bij de borrels en kwartaaluitjes! Kortom; een jaar lang hard aan jezelf werken in combinatie met gezelligheid en plezier. Spreek dit jou aan? Dan komen we

Bekijk vacature »

Traineeship Full Stack Java developer

Dit ga je doen Start jij op 7 augustus bij de Experis Academy dan kickstart jij jouw IT-carrière! We leiden je op tot een gewilde Full Stack Java Developer met alle kennis en vaardigheden die nodig zijn om de arbeidsmarkt te betreden. Wat kun je verwachten, hoe zit een dag in het leven van een Trainee eruit? Periode 1 Als Full Stack Java Developer Trainee volg je vanuit huis een op maat gemaakte onlinetraining die in het Engels wordt gegeven. De tijd die je kwijt bent aan het volgen van de training kun je vergelijken met een fulltime werkweek. In

Bekijk vacature »

Low code Developer

Dit ga je doen Je richt je op het doorontwikkelen van bestaande applicaties en het geheel van scratch af aan opzetten van nieuwe applicaties binnen een low code platform; Je beoordeelt technisch ontwerpen en maakt de vertaalslag naar de technische oplossingen binnen het platform; Je voert testwerkzaamheden uit; Je adviseert de organisatie op jouw vakgebied; Je schakelt met business analisten en de architect om tot mooie oplossingen te komen; Je lost bugs op en denkt mee over een structurele oplossing. Hier ga je werken Het gaat om een bekend internationaal handelsbedrijf met ruim 800 medewerkers, verdeeld over verschillende deelbedrijven. Deze

Bekijk vacature »

Traineeship Java Developer

Functie Wat ga je doen als Java Developer? Jij start via ons bij deze opdrachtgever als Trainee Java ontwikkelaar, tijdens het traineeship ga je in 1 jaar van de basis naar professioneel Java ontwikkelaar. Je start samen met een groep trainees, volgt de aangeboden cursussen en gaat aan de slag bij één van onze opdrachtgevers. Na een aantal maanden volgt de volgende opdracht. Door de groei in jouw rol kom je op steeds complexere opdrachten terecht. Veel afwisseling dus. Collega’s met ervaring helpen je bij deze groei en samen met jouw coach ga je een persoonlijke leerplan opzetten om jou

Bekijk vacature »

IT Manager team PaaS

TenneT is hard groeiende om haar ambities waar te kunnen maken. Zo nemen wij een leidende rol in het aanjagen van de energietransitie. Het werven van nieuw talent speelt daarin een cruciale rol. Wij zijn op zoek naar een gedreven Lead PaaS die hieraan wil bijdragen en misschien ben jij dat wel? Jouw bijdrage aan TenneT Je wordt de Teammanager (Lead) van een nieuw team binnen de afdeling Basic van Information Technology and Facilities (ITF) van TenneT. Het team heet Platform as a Service. Hier wordt elke dag in een goede sfeer met zijn allen hard gewerkt om vanuit IT

Bekijk vacature »

Mendix Developer

Voor Troostwijk Groep zoeken wij een: Mendix Developer Wij zoeken Je bent een getalenteerde en ervaren Mendix Developer en het is tijd om je horizon te verbreden. Je wilt minder coderen en meer modelleren, minder bezig zijn met allerlei technische details en randvoorwaarden en meer met functionaliteit. Daarnaast ben je trots op de innovatieve en gebruiksvriendelijke applicaties die je in de loop van de jaren hebt gebouwd. Werk je graag in een enthousiast team, wil je veel vrijheid en kun je tegelijkertijd goed met deadlines omgaan, dan ben jij absoluut degene die wij zoeken! Wat je nodig hebt is ruime

Bekijk vacature »

Medior Java developer (fullstack)

Wat je gaat doen: Of beter nog, wat wil jij doen? Binnen DPA GEOS zijn we dan ook op zoek naar enthousiaste Java developers om ons development team te versterken. Als Java developer werk je in Agile/Scrum teams bij onze klanten en daarbij kun je eventueel ook andere ontwikkelaars begeleiden in het softwareontwikkelproces. Verder draag je positief bij aan de teamgeest binnen een projectteam en je kijkt verder dan je eigen rol. Je gaat software maken voor verschillende opdrachtgevers in jouw regio. Je bent een professional die het IT-vak serieus neemt en kwaliteit levert. Je leert snel vanwege je diepgaande

Bekijk vacature »

Full stack developer Python, React

Functie Jij als full stack developer komt binnen onze Technology afdeling te werken. Deze bestaat momenteel uit 15 man. De stack waarmee wij werken is voornamelijk Python, Javascript, React en GraphQL. Binnen deze afdeling wordt er met multidisciplinaire teams gewerkt aan verschillende projecten. Projecten duren vaak langer dan 3 maanden en je bent van begin tot eind vaak betrokken. Naast dat je als full stack ontwikkelaar aan de slag gaat ben je ook Consultant. Dit betekent dat je ook klantcontact hebt in je rol en werkshops geeft. De verhouding tussen deze werkzaamheden zijn ongeveer 70% development en 30% consultancy. Een

Bekijk vacature »

Back end developer PHP, Laravel

Functie Jij komt te werken in ons webdevelopment team, wat bestaat uit 8 ervaren collega’s. Hiernaast hebben wij nog een team van 2 ontwikkelaars die aan native applicaties werken. Bij ons zijn er korte lijntjes en er hangt een gezellige informele werksfeer. Maar het belangrijkste is natuurlijk dat je aan geweldige applicaties zult gaan werken! Wij willen als organisatie niet te groot worden, we willen gewoon toffe dingen maken. Onze techstack bestaat momenteel uit: PHP, Laravel, Javascript, Typescript, Git, MySQL, Java, Kotlin, Xamarin. Samen met ons ga jij zorgen dat we puik werk leveren! Waarbij je bij elke fase in

Bekijk vacature »

Junior Developer Low-code

Dit ga je doen Low-code ontwikkeling van software voor landelijk bekende organisaties; Samenwerken in een team van 10 collega's; Opleveren van mooie eindproducten, middels de Agile methodiek; Direct contact met de eindklant over de gewenste oplossingen. Hier ga je werken Als startende IT-professional kom je te werken in de regio van Lelystad bij een organisatie die met toonaangevende klanten uit heel Nederland samen werkt. De producten en diensten van de organisatie bereiken miljoenen Nederlanders. Hierbij komt een grote hoeveelheid informatie kijken en deze moet discreet en veilig verwerkt worden. De processen die hierbij horen worden door het IT team vormgegeven.

Bekijk vacature »
Roel -

Roel -

08/01/2012 17:50:29
Quote Anchor link
Hoi hoi,

Ik ben momenteel bezig met OOP maar ik blijf nog steeds ouderwets programmeren, omdat ik gewoon nog niet precies weet hoe ik OOP moet werken. Ik doe daarom veel oefeningen en nu ben ik een gastenboek aan het maken.

Ik doe dit dus op de OOP manier, en tevens gebruik ik MySQLi OOP.
Waar ik nu echter mee vastloop, is het ophalen van reacties.

Dit is m'n code:
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
<?php
class Gastenboek {

        $mysqli = new mysqli('localhost', 'root', '', 'gastenboek');
        
        public function getReacties() {
                $query = "SELECT naam, reactie FROM gastenboek ORDER BY datum DESC";
                $sql = $mysqli->query($query);
                if ($sql) {
                        
                }
        }


        public function plaatsReactie(Reactie $reactie) {
                $query = "INSERT INTO gastenboek (naam, reactie, ipadres, datum) VALUES ('".$mysqli->real_escape_string($reactie->getNaam())."', '".$mysqli->real_escape_string($reactie->getReactie())."', '".$mysqli->real_escape_string($reactie->getIP())."', NOW())";
                $sql = $mysql->query($query);
                if (!$sql) {
                        throw new Exception('De reactie kon niet toegevoegd worden!');
                }
        }
}


class Reactie {
        private $_naam, $_reactie, $_ip;
        
        public function __construct($naam, $reactie, $ip) {
                $this->_naam = $naam;
                $this->_reactie = $reactie;
                $this->_ip = $ip;
        }

        
        public function getNaam() {
                return $this->_naam;
        }

        
        public function getReactie() {
                return $this->_reactie;
        }

        
        public function getIP() {
                return $this->_ip;
        }
}

?>


Wat ik nu eigenlijk zou willen, is dat ik het volgende kan gebruiken om reacties te tonen:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
$gastenboek
= new Gastenboek();
while ($reactie = $gastenboek->getReacties()) {
        echo 'Naam: '.$reactie->getNaam().'<br />';
        echo 'Reactie: '.$reactie->getReactie().'<br /><br />';
}

?>


Ik heb alleen totaal geen idee hoe ik dit zou moeten oplossen. De 'Reactie' class gebruik ik voor het aanmaken van een reactie. Althans, dat was de bedoeling, maar nu schiet me net te binnen dat ik die ook zou kunnen gebruiken om reacties te tonen.

Of de code verder werkt weet ik niet, ik heb hem namelijk nog niet getest.
Ik hoop dat iemand me kan helpen!
 
PHP hulp

PHP hulp

25/04/2024 21:54:04
 
Wouter J

Wouter J

08/01/2012 17:57:08
Quote Anchor link
Je hebt bij een gastenboek te maken met meerdere objecten. Je hebt een Gastenboek, dat is al je eerste object. Dit gastenboek heeft een aantal of 1 eigenschap(pen) (properties). De eigenschap is een reactie. Dus dan heb je object 2, de reactie. Een reactie heeft als eigenschappen de User en de Content. Dat zijn dus properties, en eigenschappen, van Reactie. De User zou zelf ook nog een object kunnen zijn, maar zo ver gaan we niet.

Nu gaan we kijken, welk object moet de reactie ophalen. Moet de reactie zichzelf ophalen? Of moet het gastenboek de reactie ophalen? Of heb je een aparte class nodig om de reacties op te halen?
Gewijzigd op 08/01/2012 17:57:36 door Wouter J
 
Roel -

Roel -

08/01/2012 18:01:22
Quote Anchor link
Ik heb zelf ook al gedacht om een class aan te maken die bijvoorbeeld heet 'Reactiesgrabber', maar om hier nou een speciale class voor aan te maken lijkt me ook weer onnodig.

Maar van de andere kant, als ik die koppel aan het gastenboek ( $gastenboek->setGrabber(new Reactiegrabber()) ) zou het ook prima kunnen.

Of denk ik nu verkeerd?
 
Wouter J

Wouter J

08/01/2012 18:06:26
Quote Anchor link
Je denkt al iets te moeilijk. Overigens Reactiesgrabber, zoiets heet een Datamapper en dat is in dit geval nog veel te moeilijk.

We hebben het main object Gastenboek. Dit omvat alles. Een gastenboek heeft reacties als eigenschap en propertie. Doormiddel van methods kun je properties wijzigen. Een gastenboek kan dus reacties ophalen, toevoegen, verwijderen, bewerken, enz.

Ik schrijf het liefst altijd voordat ik begin alles uit zonder code te schrijven. Zo heb je een beeld van hoe de objecten zijn, wat ze inhouden, enz:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
ClassName
  - eigenschap
  + methode()
  + andereMethode( $var )

Hierbij is - en + de visibility, public private en protected. Probeer eens zo'n diagram te maken voor een Gastenboek waarbij je in je achterhoofd houdt dat Gastenboek reacties als eigenschap heeft en deze kan bewerken.
Gewijzigd op 08/01/2012 18:08:46 door Wouter J
 
Roel -

Roel -

08/01/2012 18:26:49
Quote Anchor link
Ik heb het met Visual Paradigm gemaakt (een tool van school).
Erg bekend met het programma ben ik nog niet, maar dat geeft niet.
Afbeelding

Ik heb het MySQLi gedeelte er voor nu maar even uit gehaald, want dat snap ik nog niet helemaal. Als ik dit plaatje implementeer kom ik hierop uit en dit 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
<?php
class Gastenboek {

        private $_reacties = array();
        
        public function getReacties() {
                return $this->_reacties;
        }


        public function plaatsReactie(Reactie $reactie) {
                $this->_reacties[] = $reactie;
        }
}


class Reactie {
        private $_naam, $_reactie, $_ip;
        
        public function __construct($naam, $reactie, $ip = '') {
                $this->_naam = $naam;
                $this->_reactie = $reactie;
                $this->_ip = $ip;
        }

        
        public function getNaam() {
                return $this->_naam;
        }

        
        public function getReactie() {
                return $this->_reactie;
        }
}


$gastenboek = new Gastenboek();
$gastenboek->plaatsReactie(new Reactie('Roel', 'Voorbeeld'));
foreach ($gastenboek->getReacties() as $reactie) {
        echo 'Naam: '.$reactie->getNaam().'<br />';
        echo 'Reactie: '.$reactie->getReactie();
}

?>


Nu mezelf maar aan een database wagen... :)
 
Wouter J

Wouter J

08/01/2012 18:33:14
Quote Anchor link
Kijk dat ziet er heel goed uit! De OO gedachte is er zo te zien wel. Mag ik vragen waarom je met MySQLi werkt? Je kan -vind ik- veel beter met PDO werken in OO.

Verder moet je per bericht een update naar de db doen er een bericht bij plaatsen en in de constructor van Gastenboek moet je alle berichten ophalen uit de db en plaatsen in $_reacties. Hierdoor heb je alle berichten al.
 
Roel -

Roel -

08/01/2012 18:59:55
Quote Anchor link
Bedankt voor de tips. Ik heb geprobeerd het via PDO te doen en dit lukt denk ik niet helemaal goed. M'n database is nu opgezet maar ik heb 'ip' weggehaald (ook uit de code).

Ik probeer een error af te vangen, maar dit lukt geloof ik niet helemaal. Ook wordt er geen record ingevoegd, dus het gaat fout, maar ik krijg geen exception.
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
<?php
class Gastenboek {

        private $_db, $_reacties = array();
        
        public function __construct(PDO $connectie) {
                $this->_db = $connectie;
        }

        
        public function getReacties() {
                return $this->_reacties;
        }


        public function plaatsReactie(Reactie $reactie) {
                $query = "INSERT INTO gastenboek (naam, reactie, ip) VALUES (:naam, :reactie)";
                $statement = $this->_db->prepare($query);
                $statement->bindParam(':naam', $reactie->getNaam(), PDO::PARAM_STR);
                $statement->bindParam(':reactie', $reactie->getReactie(), PDO::PARAM_STR);
                $statement->execute();
        }
}


class Reactie {
        private $_naam, $_reactie;
        
        public function __construct($naam, $reactie) {
                $this->_naam = $naam;
                $this->_reactie = $reactie;
        }

        
        public function getNaam() {
                return $this->_naam;
        }

        
        public function getReactie() {
                return $this->_reactie;
        }
}


try {
        $database = new PDO('mysql:host=localhost;dbname=gastenboek', 'root', '');

        $gastenboek = new Gastenboek($database);
        $gastenboek->plaatsReactie(new Reactie('Roel', 'Voorbeeld'));
}
catch (PDOException $e) {
        echo 'Fout: '.$e->getMessage();
}

foreach ($gastenboek->getReacties() as $reactie) {
        echo 'Naam: '.$reactie->getNaam().'<br />';
        echo 'Reactie: '.$reactie->getReactie();
}

?>
 
Wouter J

Wouter J

08/01/2012 19:47:45
Quote Anchor link
Plaats gewoon alles in de try en vang de fouten op.

Tevens moet je met PDO setAttribute() gebruiken om met exceptions te werken (wat wel is aan te raden):
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
<?php

try
{
  $db = new PDO('mysql:host=localhost;dbname=naam', 'user', 'pass');
  $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  $guestbook = new Gastenboek( $db );
}

catch( Exception $e )
{

  if( $e instanceof PDOException )
  {

    echo 'Error with DB: '.$e->getMessage();
  }

  else
  {
    echo 'Error: '.$e->getMessage();
  }
}

?>


In je query hebt je nog ip vergeten weg te halen. En je slaat nergens de gegevens op in $_reacties. Dit is hoe ik het zou doen:
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
<?php

class Guestbook
{
  protected $reactions = array();
  protected $_db;

  public function __construct( PDO $db )
  {

    $this->_db = $db;

    // De select query
    $sQuery = "SELECT user, content FROM guestbook";
    $stmt = $this->_db->prepare($sQuery);
    $stmt->execute();

    while( $row = $stmt->fetch(PDO::FETCH_ASSOC) )
    {

      $this->reactions = new Reaction( $row['user'], $row['content'] );
    }
  }


  public function addReaction( Reaction $reaction )
  {

    $iQuery = "INSERT INTO guestbook ( user, content ) VALUES ( :name, :content )";
    $stmt = $this->_db->prepare($iQuery);
    $stmt->execute(Array(
      ':name', $reaction->getName(),
      ':content', $reaction->getContent()
    ));

    $this->reactions = $reaction;
  }


  public function getReactions()
  {

    return $this->reactions;
  }
}


class Reaction
{
  protected $user;
  protected $content;

  public function __construct( $user, $content )
  {

    $this->user = (string) $user;
    $this->content = (string) $content;
  }


  public function getName()
  {

    return $this->user;
  }

  public function getContent()
  {

    return $this->content;
  }
}

?>
 
Roel -

Roel -

08/01/2012 20:48:02
Quote Anchor link
Bedankt, hier kan ik veel van leren!
Waarom gebruik je overigens type cast? Ik snap nog steeds niet wanneer dat handig is in PHP, aangezien ze geen onderscheid maken tussen datatypes.
 
Synaps Framework

Synaps Framework

08/01/2012 20:54:05
Quote Anchor link
1 vraag: Waarom het database object parsen via de constructor en opslaan in een property? Sinds wanneer is het database object onderdeel van een gastenboek?
 
Wouter J

Wouter J

08/01/2012 21:10:24
Quote Anchor link
@Synaps, het db object is geen onderdeel van Gastenboek (vandaar dat ik _db gebruikte, dat gebruik ik voor properties die niet horen via OO maar nodig zijn voor de code). Hoe wil je het anders doen, via een global var? Of telkens de verbinding opnieuw aanmaken? Dit is de manier die ik altijd heb aangeleerd.

Roel van de Water:
Waarom gebruik je overigens type cast? Ik snap nog steeds niet wanneer dat handig is in PHP, aangezien ze geen onderscheid maken tussen datatypes.

Omdat ik vanuit C# gewent ben om altijd types mee te geven aan variabelen. En ik wil zeker zijn dat het geen er in de properties zit ook echt is wat ik wil dat erin zit.

Ik ben vergeten weer te geven hoe je die classes nou gebruikt:
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
<?php
try
{
  $pdo = new PDO('mysql:host=localhost;dbname=tabelnaam', 'user', 'pass');
  $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

  $guestbook = new Guestbook($pdo);

  foreach( $guestbook->getReactions() as $reaction )
  {

    echo '<h4>'.$reaction->getName().'</h4><p>'.$reaction->getContent().'</p>';
  }


  if( reactie_toevoegen )
  {

    $guestbook->addReaction( new Reaction( $_POST['name'], $_POST['content'] ) );
  }
}

catch(Exception $e)
{

  // Doe wat leuks.
}[/code]
Gewijzigd op 08/01/2012 21:10:46 door Wouter J
 
Synaps Framework

Synaps Framework

08/01/2012 21:49:40
Quote Anchor link
@Wouter, als je voor de gein het gasteboek object var_dumpt, zul je dus zien dat ook het gehele db object word gedumpt.

Een hele rotzooi.

Wat soms ook gedaan word is, wanneer je een functie aanroept welke de database nodig heeft, de database object word opgehaald via singleton.

Dit resulteert is schonere objecten. Daarnaast kun je geen resources serializen. Mocht je dit object dus wel willen serializen, dan moet je daarvoor weer een fix voor in bouwen.
 
Jelmer -

Jelmer -

08/01/2012 23:40:25
Quote Anchor link
Synaps Framework op 08/01/2012 20:54:05:
1 vraag: Waarom het database object parsen via de constructor en opslaan in een property? Sinds wanneer is het database object onderdeel van een gastenboek?

Dit gastenboek is onlosmakelijk gekoppeld met die database-verbinding. Netter zou zijn om het opslaan van de berichten weer in een ander object af te handelen, maar je moet ergens stoppen met abstraheren :) (In zo'n geval zou je een Reactie-object hebben dat een reactie beschrijft, een Gastenboek-object dat de regels van een gastenboek beschrijft, en een Reactie-store dat de reacties voor het gastenboek opslaat op een of andere manier. Dan kan je de methode van opslaan veranderen zonder je Reactie- of Gastenboek-class te veranderen. Je hoeft alleen maar een andere store mee te geven.)

Quote:
Mocht je dit object dus wel willen serializen, dan moet je daarvoor weer een fix voor in bouwen.

En dat heb je dan ook meteen goed afgevangen. Met een magic method zorg je er dan voor dat je alleen de array met reacties serialized. Hoe je dan weer een werkend en verbonden gastenboek terugkrijgt wanneer je het unserialized, ik vraag me af of je dat moet willen. Grote kans dat dingen out-of-sync raken als je dit soort dingen gaat doen.

Quote:
Wat soms ook gedaan word is, wanneer je een functie aanroept welke de database nodig heeft, de database object word opgehaald via singleton.

Singletons zorgen juist voor nog hardere koppelingen. Twee gastenboeken naast elkaar op verschillende databases kan je dan niet. Of heel ranzig. Singletons zou ik juist ten alle tijden proberen te vermijden. Die zijn net zo erg als globale variabelen. Wat zeg ik, het zijn globale variabelen, maar dan met een klein beetje meer controle vanuit de singelton zelf. Niet vanuit de gebruikende class, dat is het hele probleem. Geen idee welke andere class m'n singleton object zit aan te passen terwijl ik het gebruik. Brr. Leuk voorbeeld: een singelton database-verbinding en transacties.
 
Synaps Framework

Synaps Framework

09/01/2012 09:27:58
Quote Anchor link
Jelmer rrrr op 08/01/2012 23:40:25:
Synaps Framework op 08/01/2012 20:54:05:
1 vraag: Waarom het database object parsen via de constructor en opslaan in een property? Sinds wanneer is het database object onderdeel van een gastenboek?

Dit gastenboek is onlosmakelijk gekoppeld met die database-verbinding. Netter zou zijn om het opslaan van de berichten weer in een ander object af te handelen, maar je moet ergens stoppen met abstraheren :) (In zo'n geval zou je een Reactie-object hebben dat een reactie beschrijft, een Gastenboek-object dat de regels van een gastenboek beschrijft, en een Reactie-store dat de reacties voor het gastenboek opslaat op een of andere manier. Dan kan je de methode van opslaan veranderen zonder je Reactie- of Gastenboek-class te veranderen. Je hoeft alleen maar een andere store mee te geven.)

Quote:
Mocht je dit object dus wel willen serializen, dan moet je daarvoor weer een fix voor in bouwen.

En dat heb je dan ook meteen goed afgevangen. Met een magic method zorg je er dan voor dat je alleen de array met reacties serialized. Hoe je dan weer een werkend en verbonden gastenboek terugkrijgt wanneer je het unserialized, ik vraag me af of je dat moet willen. Grote kans dat dingen out-of-sync raken als je dit soort dingen gaat doen.

Quote:
Wat soms ook gedaan word is, wanneer je een functie aanroept welke de database nodig heeft, de database object word opgehaald via singleton.

Singletons zorgen juist voor nog hardere koppelingen. Twee gastenboeken naast elkaar op verschillende databases kan je dan niet. Of heel ranzig. Singletons zou ik juist ten alle tijden proberen te vermijden. Die zijn net zo erg als globale variabelen. Wat zeg ik, het zijn globale variabelen, maar dan met een klein beetje meer controle vanuit de singelton zelf. Niet vanuit de gebruikende class, dat is het hele probleem. Geen idee welke andere class m'n singleton object zit aan te passen terwijl ik het gebruik. Brr. Leuk voorbeeld: een singelton database-verbinding en transacties.


Singleton is zeker niet de oplossing. Wellicht kan de TS eens kijken naar de DI van Symfony? Vind het storen van een geheel DB object in je property echter een no-go.

Neemt niet weg dat TS hier geheel anders over denkt, het is puur mijn mening. Doe er dus mee wat je wilt ;).

Toevoeging op 09/01/2012 10:03:54:

Roel van de Water op 08/01/2012 17:50:29:
Wat ik nu eigenlijk zou willen, is dat ik het volgende kan gebruiken om reacties te tonen:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
$gastenboek
= new Gastenboek();
while ($reactie = $gastenboek->getReacties()) {
        echo 'Naam: '.$reactie->getNaam().'<br />';
        echo 'Reactie: '.$reactie->getReactie().'<br /><br />';
}

?>


Daarnaast, mocht je dit graag willen, dan zou je eens kunnen kijken naar ArrayObject of Iterator.

Gr.
Gewijzigd op 09/01/2012 10:06:30 door Synaps Framework
 
Gerhard l

gerhard l

22/02/2012 14:44:39
Quote Anchor link
Ik ben de laatste tijd ook een beetje aan het oefenen met OOP, ik heb de code bekeken, en het meeste spreekt wel voor zich, alleen wou ik hier graag wat meer uitleg over:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
<?php
$_POST
['name'] = 'Bob';
$_POST['content'] = 'Hallo!';

// Er wordt een reactie toegevoegd:
if( reactie_toevoegen )
  {

    //Stuur je hier nou een Class Reaction mee, zodat je de get title en content
    //kan gebruiken?

    $guestbook->addReaction( new Reaction( $_POST['name'], $_POST['content'] ) );
  }

?>


Hier wordt het bericht afgehandeld

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
<?php
// Je geeft hier class reaction dus mee
  public function addReaction( Reaction $reaction )
  {

    //query
        $iQuery = "INSERT INTO guestbook ( user, content ) VALUES ( :name, :content )";
       //prepare
    $stmt = $this->_db->prepare($iQuery);
    //execute
        $stmt->execute(Array(    
        //Deze kan je dus ophalen omdat je de class hebt meegegeven gok ik
              ':name', $reaction->getName(),
              ':content', $reaction->getContent()
        ));

    //En dan vraag ik me af wat hier nog gebeurt, zet je hier nou de extra
    //waardes (Bob, Hallo!) in de array die je tijdens de construct al hebt
    //opgebouwd vanuit je database?

        $this->reactions = $reaction;
  }

?>
Gewijzigd op 22/02/2012 14:45:11 door gerhard l
 
Wouter J

Wouter J

22/02/2012 16:50:43
Quote Anchor link
>> Stuur je hier nou een Class Reaction mee, zodat je de get title en content kan gebruiken?
Je wilt een reactie toevoegen aan een gastenboek. Allebei de onderstreepte woorden zijn objecten en dienen dus een eigen class te hebben. Als je 1 object aan het andere object toevoegt, in dit geval dus een reactie aan het gastenboek, moet je ook de ene class toevoegen aan de andere.

Verder moet je niet denken, 'ik geef de reaction class mee omdat ik later functies daarvan nodig heb in de afhandeling van de method', maar je moet denken dat je het mee geeft omdat je 1 object aan het andere toevoegt. Objecten moet je apart van elkaar gebruiken. De reaction hoeft niet te weten dat hij gebruikt wordt in een gastenboek en het gastenboek hoeft niet te weten hoe de reaction class eruit ziet. Hij moet alleen zeker weten dat de reaction class 2 methods heeft: getName en getContent.

>> Je geeft hier class reaction dus mee
Nee, het meegeven doe je in het code blok ervoor. Op deze regel geef je aan dat je als parameter van de addReaction method een Reaction object verwacht. Als je iets anders meegeeft krijg je een error.

>> Deze kan je dus ophalen omdat je de class hebt meegegeven gok ik
Ja, $reaction bevat de class Reaction en dus kun je alles gebruiken wat je wilt van die Reaction klasse.

>> En dan vraag ik me af wat hier nog gebeurt, zet je hier nou de extra waardes (Bob, Hallo!) in de array die je tijdens de construct al hebt opgebouwd vanuit je database?
Allereerst zie ik dat er een foutje staat, het moet $this->reactions[] = $reaction zijn. Mijn excusses...

Maar om op je vraag te komen. Met deze functie voegen we de nieuwe Reaction object toe aan onze array met alle reacties van dit gastenboek. Het voordeel hiervan is dat we met Gastenboek::getReactions() gewoon meteen de array reactions kunnen returnen, i.p.v. eerst een DB query uit te voeren.
Tevens kun je vanuit OO oogpunt zeggen dat de reactions een eigenschap, en dus een propertie, is van het object Gastenboek.
 



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.