ID.nl logo
Cursus: Een persoonlijke VPN instellen
© PXimport
Zekerheid & gemak

Cursus: Een persoonlijke VPN instellen

Een VPN-verbinding (Virtual Private Network) wordt regelmatig gebruikt in een zakelijke omgeving. Toch komt het ook voor persoonlijk gebruik wel eens van pas, vooral als je veel van huis bent en verbinding maakt met het internet via onbetrouwbare wifi-netwerken. Wij leggen uit wat met een VPN mogelijk is en hoe je aan de slag kunt.

Velen kennen een VPN () wel van hun werk: je kunt dan vanuit huis bij alle interne websites en gedeelde bestanden op het intranet van het bedrijf, maar niet zonder eerst verbinding te maken met het VPN van je bedrijf.

Alle netwerkcommunicatie tussen je thuiscomputer (of hotelcomputer tijdens een vakantie) en het bedrijf verloopt dan versleuteld, zodat je geen bedrijfsgeheimen lekt. Iemand die bijvoorbeeld een netwerksniffer bij je thuis of in je hotel geïnstalleerd heeft, krijgt dan geen enkele kans als alle communicatie via het VPN verloopt. Ook om meerdere vestigingen van een bedrijf op een veilige manier met elkaar te verbinden worden VPN’s ingezet.

De voordelen van een externe VPN-dienst

Er bestaan heel wat externe VPN-diensten waarvan je gratis (voor een beperkte bandbreedte) of voor een vast maandelijks bedrag gebruik kunt maken. Wat is hier zoal mee mogelijk? Het belangrijkste voordeel is dat je nu vanaf elke locatie veilig kunt internetten, zelfs als je verplicht bent om via een onveilig open wifi-netwerk te surfen. Je verbindt dan met het onveilige netwerk en zet onmiddellijk daarna een veilige verbinding op met de VPN-server. Zodra dit gebeurd is, surf je veilig zonder dat speurneuzen in de buurt jouw digitale doen en laten kunnen volgen. Een ander voordeel van zo’n externe VPN-dienst is dat je er je IP-adres mee verbergt voor websites die je niet vertrouwt: zij zien dan immers het IP-adres van de VPN-server waarmee je verbonden bent. En tot slot is een externe VPN-dienst ook handig om regioblokkeringen te omzeilen: surf je bijvoorbeeld via een Amerikaanse VPN, dan bekijk je probleemloos series en films op Hulu.com.

01 Huiskamer-VPN

In de huiskamer is een VPN nog niet zo ingeburgerd, tenzij dan als gebruiker van een extern VPN. Je kunt niet alleen met het VPN van je bedrijf verbinden, maar ook met een externe VPN-dienst, gratis of betaald (zie ook kader “De voordelen van een externe VPN-dienst”).

Maar wist je dat het ook mogelijk is om zelf een VPN-server op de computer thuis te draaien, zodat je de rollen omdraait? Je kunt dan van buitenshuis een veilige verbinding opzetten met de computer, of dat nu met een laptop, tablet of smartphone is. Maar waarom zou je dit doen? Daar kunnen verschillende redenen voor zijn. Misschien vind je het eenvoudigweg handig dat je van thuis uit toegang hebt tot de bestanden die gedeeld zijn in het bedrijfsnetwerk van je werkgever en wil je hetzelfde doen met jouw persoonlijke bestanden.

Of misschien wil je van overal veilig kunnen internetten, ook als je verplicht bent een onveilig open wifi-netwerk te gebruiken. Ook dit kan door een VPN-verbinding naar je thuiscomputer. Al het netwerkverkeer wordt dan versleuteld naar de pc gestuurd, zodat een netwerksniffer op het onveilige netwerk niets kan afluisteren en je surft dan eigenlijk via de omweg van de internetprovider thuis.

Ook kun je als je op vakantie bent in het buitenland en Uitzending Gemist wilt bekijken dit via een VPN-verbinding naar je huis doen. Uitzending Gemist blokkeert immers bezoekers van het buitenland, maar als je via de computer in Nederland surft, ziet de website een Nederlands IP-adres en lukt het wel. Kortom, genoeg redenen om een VPN-server op je computer te zetten.

02 Voorbereiding

Windows 7 beschikt van huis uit al over de mogelijkheid om een VPN-server op te zetten die dan via internet te bereiken is, al ondersteunt die maar één gelijktijdige verbinding. Aangezien jouw computer thuis echter achter een router hangt, is er nooit een rechtstreekse verbinding van internet naar de computer mogelijk en is je computer dus niet als server bereikbaar. Daarom moet je in de router ‘port forwarding’ instellen: als je router dan een aanvraag van een VPN-client ontvangt, stuurt het deze door naar je computer.

Port forwarding in de router

Hoe je de poort voor het VPN-verkeer in de router moet laten doorsturen naar de computer waarop de VPN-server draait, hangt van het model en merk van de router af. Als voorbeeld tonen we hoe dit in de firmware DD-WRT (www.dd-wrt.com) verloopt. In de webinterface van de router klik je bovenaan op het tabblad NAT/QoS en dan op Port Forwarding. Klik dan op het knopje Add en maak een regel aan om een poort door te sturen. In het vakje Application vul je in wat u wilt, bijvoorbeeld ‘VPN’, dit dient enkel als geheugensteuntje voor jezelf. Zowel bij Port from als Port to vul je 1723 in (het poortnummer voor het PPTP-protocol dat door de Windows VPN-software gebruikt wordt). Bij IP Address vul je het IP-adres van de computer in waarop de VPN-server draait en bij Protocol klik je op TCP. Vink Enable aan, klik tot slot op Add om de regel toe te voegen en op Save en Apply Settings om dit op te slaan. Bij andere firmware werkt dit vergelijkbaar, en in sommige routers moet je ook het protocol GRE (Generic Route Encapsulation) forwarden of een optie VPN Passthrough inschakelen.

©PXimport

Laat poort 1723 naar je VPN-server doorsturen.

De computer moet ook altijd hetzelfde lokale IP-adres op het thuisnetwerk hebben, anders stuurt de router de VPN-netwerkpakketjes naar de verkeerde computer zodra die een ander IP-adres krijgt. Lees in het kader ‘Altijd hetzelfde IP-adres’ hoe je dit instelt. Een derde eis is dat het modem van buitenaf te bereiken is op een bekend IP-adres. Aangezien de meeste internetproviders aan de modems van niet-bedrijfsabonnementen geen vast extern IP-adres toekent, moet je een dynamisch DNS-adres op de router instellen. Lees in het kader ‘Dynamische DNS’ hoe je dit doet.

Altijd hetzelfde IP-adres

Op de meeste thuisnetwerken deelt de router IP-adressen uit aan alle verbonden machines met het DHCP-protocol (Dynamic Host Configuration Protocol). Handig, omdat je dan op de computers normaal gesproken geen enkele netwerkconfiguratie meer moet doen. Je steekt de netwerkkabel gewoon in en de computer krijgt een IP-adres toegekend. Vaak krijgt je computer hetzelfde IP-adres toegekend, maar dat wordt niet gegarandeerd. Een vast IP-adres is bij port forwarding echter een vereiste om als server bereikbaar te zijn. Gelukkig kun je in de instellingen van de router opgeven dat de DHCP-server aan specifieke computers een vast IP-adres toekent. In de webinterface van onze voorbeeldrouter (de DD-WRT) vinden wij deze mogelijkheid op de pagina Services bij DHCP Server. Al moet je voordat je aan zo’n klus begint even het MAC-adres van de netwerkverbinding opzoeken: hiervoor klik je met rechts in het netwerkmenu op de netwerkverbinding, kies Status / Details en kijk bij Fysiek adres. In de webinterface van onze router klikken we vervolgens onder Static Leases op Add, vullen we het MAC-adres van de computer in, plus de hostnaam en het IP-adres dat we willen toekennen. We klikken Save en Apply Settings om dit op te slaan.

©PXimport

Zorg dat je VPN-server altijd hetzelfde IP-adres krijgt.

Dynamische DNS

Aangezien het externe IP-adres van je modem niet gegarandeerd hetzelfde blijft, kun je dit niet in de VPN-client ingeven, want zodra het IP-adres verandert, is het niet meer mogelijk om op de VPN-server in te loggen. Een oplossing vormt dynamische DNS: je vraagt dan een subdomein aan bij een (meestal gratis) dynamische-DNS-dienst, en de modem laat dit subdomein steeds verwijzen naar het juiste IP-adres. Elke keer dat de modem een ander extern IP-adres toegekend krijgt, stuurt de firmware dan een aanvraag naar de dynamische-DNS-dienst om het subdomein naar het nieuwe IP-adres te laten verwijzen. Dan hoef je dus enkel maar het gekozen subdomein te onthouden. In de webinterface van DD-WRT vind je de instellingen van dynamische DNS in het tabblad Setup > DDNS. Kies je dynamische-DNS-dienst in het menu en geef je gebruikersnaam en wachtwoord bij de dienst op. Vul ook het gekozen subdomein in (bijvoorbeeld example.dyndns.org) en klik tot slot op Save en Apply Settings om de instellingen op te slaan.

©PXimport

Maak je router van overal bereikbaar via een dynamische-DNS-dienst.

03 Je computer als VPN-server

Voldoet je computer aan de drie vereisten (een vast IP-adres met port forwarding hiernaar ingesteld in de router en dynamische DNS ingesteld), dan kun je beginnen met het opzetten van de VPN-server. Open het Configuratiescherm van Windows, selecteer Netwerk en internet en daarna Netwerkcentrum. Klik in de linkerzijbalk op Adapterinstellingen wijzigen. Je krijgt nu al jouw geconfigureerde netwerkverbindingen te zien. Druk op Alt om het hoofdmenu te tonen en kies in het menu Bestand de optie Nieuwe binnenkomende verbinding. Windows start nu een wizard op die je helpt bij het opzetten van een VPN-server.

In het eerste venster kies je welke gebruikers toegang krijgen tot de computer en het netwerk via VPN. Klik dan op Volgende, waarna je in het volgende venster kiest op welke manier gebruikers verbinden. Kies hier Via internet en klik op Volgende. In het laatste venster van de wizard selecteer je de netwerkprotocollen die bereikbaar zijn. De standaardkeuze is vaak voldoende. Kijk na of IPv4 ingeschakeld is en (als je gedeelde bestanden op het thuisnetwerk wil bereiken) Bestands- en printerdeling voor Microsoft-netwerken.

Klik op Toegang toestaan, waarna de wizard de VPN-verbinding instelt. Je krijgt tot slot een computernaam te zien, die je echter niet nodig hebt. Wanneer je het venster gesloten hebt, verschijnt er een nieuwe verbinding met de naam Binnenkomende verbindingen in het venster Netwerkverbindingen van het configuratiescherm. De serverconfiguratie is nu klaar. Zolang de computer ingeschakeld is, kun je nu van buitenaf erop inloggen.

04 Verbinding met een VPN-server in Windows instellen

Ga nu buitenshuis met een Windows-computer waarmee je met de VPN-server wilt verbinden. Open het Configuratiescherm van Windows, selecteer Netwerk en internet en daarna Netwerkcentrum. Onder De netwerkinstellingen wijzigen klik je op Een nieuwe verbinding of een nieuw netwerk instellen. Windows start dan een wizard die je helpt bij het configureren van een nieuwe netwerkverbinding. Selecteer Verbinding met een bedrijfsnetwerk maken en klik op Volgende. In de stap erna moet je kiezen hoe je met het VPN verbindt, dat zal in de meeste gevallen Mijn internetverbinding (VPN) gebruiken zijn.

In het volgende venster geef je het publieke internetadres in van de VPN-server. Dat kan een IP-adres of een domeinnaam zijn. Aangezien onze VPN-server thuis niet van een internetverbinding met een vast IP-adres kan genieten, hebben we dynamische DNS ingesteld en moet je hier dus het subdomein invullen die je bij jouw dynamische-DNS-dienstverlener gekozen hebt (zie kader ‘Dynamische DNS’). Bij Naam van doel vul je een willekeurige naam in die deze VPN-verbinding beschrijft. Daarna klik je op Volgende.

In het volgende venster geef je de gebruikersnaam en wachtwoord op van het Windows-gebruikersaccount op de computer thuis. Dit account moet bij het instellen van de VPN-server uiteraard wel bij de toegelaten gebruikers aangevinkt zijn. Klik tot slot op Verbinding maken en wanneer de verbinding geslaagd is op Sluiten.

Rechtsklik nu op de VPN-verbinding in het netwerkmenu of het onderdeel Netwerkverbindingen in het Configuratiescherm en kies Eigenschappen. Ga naar het tabblad Beveiliging en zorg ervoor dat er PPTP bij het type VPN staat. Bij Gegevensversleuteling moet Versleuteling verplicht (verbinding verbreken indien afgewezen) staan. Klik op OK, waarna de verbinding klaar voor gebruik is. Deze configuratie hoef je maar één keer te doen op elke computer die je gebruikt om met de VPN-server te verbinden.

05 Verbinding maken

Verbinden met de VPN-server is nu eenvoudig: klik op het icoontje van de VPN-verbinding in het netwerkmenu en klik op Verbinding maken. Geef de gebruikersnaam en wachtwoord van de VPN-server in wanneer daarom gevraagd wordt (tenzij je hebt gekozen om deze op te slaan) en klik nog eens op Verbinding maken. Rechtsklik je op de VPN-verbinding in het netwerkmenu, dan kun je de verbinding verbreken, of de status of eigenschappen opvragen.

Controleer of je wel het VPN gebruikt

Controleer altijd nadat je voor de eerste keer een VPN-verbinding op je client ingesteld hebt of je echt wel via het VPN surft. Dit doe je door middel van een website zoals www.whatismyip.org welke jouw publiek IP-adres weergeeft. Controleer of dit overeenkomt met het IP-adres van de VPN-server. Als je enkel het dynamische-DNS-subdomein kent, open dan een opdrachtprompt in het Windows-startmenu en type de opdracht nslookup gevolgd door het subdomein in (bijvoorbeeld nslookup example.dyndns.org). Je krijgt dan het huidige IP-adres te zien dat aan dit domein toegekend is. Als dit hetzelfde is als wat www.whatismyip.org toont, surft je via de VPN.

De status van de VPN-verbinding toont allerlei gegevens, zoals de verbindingsduur en de hoeveelheid dataverkeer. Klik je op het knopje Details, dan zie je het IP-adres dat de computer van de VPN-server krijgt (bijvoorbeeld 192.168.0.100) en de gebruikte DNS-servers. Klik je op het tabblad Details, dan zie je ook wat het IP-adres van de VPN-server in het VPN is, en het IP-adres van de VPN-server op internet. Bovendien zie je hier ook de gebruikte authenticatie (MS CHAP V2) en versleuteling (MPPE 128).

06 Verbind met een VPN-server in OS X

Je kunt ook perfect vanaf je MacBook Pro of andere Mac met de thuis-VPN verbinden. Hiervoor moet je weer eerst een VPN-verbinding configureren. Open de Systeemvoorkeuren, klik op het icoontje Netwerk, en klik indien nodig op het hangslot-icoontje linksonder om de instellingen te ontgrendelen.

Klik op het +-icoontje linksonder om een nieuwe netwerkverbinding aan te maken en kies bij Interface voor VPN. Als VPN-type selecteer je PPTP. Bij Naam voorziening vul je een naam in om de VPN-verbinding te beschrijven. Klik op Maak aan. Vul nu bij Serveradres het subdomein van de dynamische DNS-dienst in en bij Accountnaam jouw gebruikersnaam op de Windows-computer. Bij Codering kies je Maximaal (uitsluitend 128-bits).

Klik nu op Instellingen identiteitscontrole, vul het wachtwoord dat bij de Windows-gebruikersnaam hoort in en klik op OK. Je vinkt daarna best ook Toon VPN-status in menubalk aan, zodat je altijd ziet wanneer je met het VPN verbonden bent. Klik op Pas toe om al deze instellingen op te slaan. Als je dit eenmaal een keer hebt gedaan, is verbinden met de VPN-server eenvoudig: klik op het VPN-icoontje rechtsboven en klik op Verbind met [je VPN-naam]. Je verbreekt de verbinding door nog eens op het icoontje te klikken en Verbreek verbinding met [je VPN-naam] te kiezen.

07 Verbind met een VPN-server in Android

Uiteraard zou je ook graag vanaf je smartphone of tablet onderweg verbinden met je thuis-pc. Android ondersteunt van huis uit PPTP, maar helaas heeft het al jaren met een bug te maken waardoor versleutelde PPTP-verbindingen op veel Android-apparaten onstabiel zijn.

Open in Android in de instellingen Draadloos en netwerken en kies VPN-instellingen. Druk op VPN toevoegen en daarna VPN ‘PPTP’ toevoegen. Bij VPN-naam vul je een naam in die je VPN-verbinding beschrijft, en bij VPN-server instellen geef je het subdomein van de dynamische-DNS-dienst in. Zorg dat codering inschakelen aangevinkt is (tenzij de verbinding door de bug in Android onstabiel is en je de encryptie niet nodig hebt). Druk tot slot op de menuknop en dan Opslaan.

De nieuwe VPN-verbinding verschijnt nu in de lijst met VPN’s. Druk erop en geef nu de gebruikersnaam en het bijbehorende wachtwoord in voor de Windows-computer. Klik daarna op Verbinden. Tijdens de verbinding krijg je bovenaan het icoontje van een slotje te zien. Je kunt de verbinding op elk moment verbreken door bij de VPN-instellingen op de naam van de VPN-server te drukken.

©PXimport

Ook met Android kun je met de VPN-server verbinden.

08 Verbind met een VPN-server in iOS

Ook met een iPhone, iPad of iPod touch kun je op je thuisnetwerk via een beveiligde verbinding. Druk hiervoor achtereenvolgens op Instellingen / Algemeen / Netwerk en VPN. Druk op Voeg VPN-configuratie toe en kies het tabblad PPTP. Bij Beschrijving geef je een naam aan de VPN-verbinding, bij Server geef je het subdomein van de dynamische DNS-dienst in, en bij Account en Wachtwoord je gebruikersnaam en het bijbehorende wachtwoord van de Windows-computer. Zorg dat Coderingsniveau op Maximum staat en Stuur alle verkeer aan. Druk op Bewaar.

Na deze configuratie schakel je de VPN-verbinding eenvoudig in door het VPN-knopje bovenaan de lijst met VPN-verbindingen aan te zetten. Wacht tot je bij Status de boodschap Verbonden ziet staan. Bovenaan het scherm van je iOS-apparaat krijg je een blauw icoontje met de letters VPN te zien zolang je via deze verbinding internet.

©PXimport

Stel op je iOS-apparaat een VPN-verbinding naar de thuis-pc in.

09 Energie besparen

De hele dag je desktop-pc ingeschakeld laten voor die enkele keren dat je onverwacht van buitenaf aan je bestanden wil, getuigt niet van een milieubewuste instelling. Je bent energiezuiniger af met een NAS of zelfs je router als VPN-server.

Zeker als je enkel een VPN wilt opzetten om van buitenaf altijd via je vertrouwde internetverbinding te kunnen surfen over een versleutelde tunnel, is het overdreven dat je daarvoor de hele dag je pc laat aanstaan. Daarom tonen we je hier hoe je een PPTP VPN-server op de router inschakelt, aangezien die sowieso altijd aan staat. Als voorbeeld gebruiken we de opensource routerfirmware DD-WRT, maar heel wat andere routers ondersteunen dit ook.

In de webinterface van DD-WRT klik je op het tabblad Services en daarna op VPN. Je hebt op deze pagina vier mogelijkheden: PPTP Server (wat we hier nodig hebben), PPTP Client (zie ook het kader ‘Je router als VPN-client’), OpenVPN Daemon (zie ook het kader ‘Er is meer dan PPTP’) en OpenVPN Client. Klik op Enable bij de eerste optie, waarna je de instellingen van de PPTP-server te zien krijgt.

©PXimport

Met je router als VPN-client surfen al jouw apparaten automatisch via het VPN.

Bij Server IP geef je 0.0.0.0 in. De router kijkt dan zelf wat zijn WAN IP-adres is. Dit adres wordt via een dynamische DNS-dienst (zie kader ‘Dynamische DNS’) toegekend aan een subdomein, dat je dan in de clients ingeeft om de VPN-server op je router te bereiken. Schakel Force MPPE Encryption in. Bij Client IP(s) geef je het adresbereik in van IP-adressen die clients toegekend krijgen. Stel bijvoorbeeld 192.168.0.200-250 in en zorg dat de router deze adressen niet aan interne clients toekent.

In het veld CHAP-Secrets tot slot geef je een lijst van gebruikersnamen en bijbehorende wachtwoorden op die op het VPN mogen verbinden. Dat moet in de vorm gebruikersnaam * wachtwoord *, met elke account op een afzonderlijke regel. Klik op Save en op Apply Settings, waarna je vanaf elk apparaat van buitenaf met de VPN-server van je router kunt verbinden. Het enige dat je moet weten om de client in te stellen, is de dynamische-DNS-subdomein en een gebruikersnaam en wachtwoord die je in de router ingesteld hebt.

Je router als VPN-client

Als je een externe VPN-dienst gebruikt, bijvoorbeeld om regioblokkeringen te omzeilen, moet je op elk apparaat waarmee je deze VPN-server wilt gebruiken de verbinding configureren. Er is een handigere oplossing: draai op een afzonderlijk draadloos toegangspunt een VPN-client (dus geen server!) die met die server verbindt. Elk apparaat dat nu met dat toegangspunt verbindt, surft nu via die VPN-dienst. Als je dus vaak Hulu.com op verschillende computers wilt bekijken, installeer dan een extra draadloos toegangspunt en configureer hierop een verbinding met een Amerikaanse VPN-server. Elke keer dat je Hulu.com wilt zien, verbind je op de computer met dat toegangspunt in plaats van met je standaard toegangspunt. Als je terug naar je normale internetverbinding wilt, schakel je eenvoudigweg over naar het standaard toegangspunt. In de webinterface van DD-WRT kun je de router als VPN-client instellen, waarbij je de keuze hebt uit PPTP of OpenVPN.

▼ Volgende artikel
Van prompt naar programma: leer programmeren met AI
© monsitj - stock.adobe.com
Huis

Van prompt naar programma: leer programmeren met AI

Niet alleen het saaie en repetitieve werk wordt vervangen door AI. Je bent óók als kenniswerker niet meer zeker van een baan. Software wordt al grotendeels door AI geschreven. Gelukkig kun je daar als hobbyprogrammeur ook enorm van profiteren. Het brengt naast tijdwinst ook veel gemak. We helpen je op weg met drie praktische tools: ChatGPT, Aider en de Windsurf Editor. We maken enkele eenvoudige voorbeelden, zodat je een helder beeld hebt van je potentiële workflow.

In dit artikel laten we zien hoe je met hulp van AI razendsnel leert programmeren en zelfs complete programma’s bouwt:

  • Gebruik ChatGPT als programmeerpartner en laat het een volledig werkend spelletje bouwen met HTML, CSS en JavaScript
  • Installeer Aider en gebruik het in combinatie met Git om projecten via de terminal te ontwikkelen
  • Ontdek Windsurf Editor als grafisch alternatief met AI-assistent Cascade

Lees ook: Leren programmeren? Met deze tools is coderen geen geheimcode meer

Grote taalmodellen zijn al zo goed dat je comfortabel complete programma’s door AI kunt laten maken, zelfs zonder enige programmeerkennis. Afhankelijk van de tools die je gebruikt, voelt dat toch alsof je samen aan code werkt, ook wel pair-programmeren genoemd. Je houdt dus enige controle en kunt er, als je oplet, veel van leren. Ook al wordt het harde werk door AI gedaan.

Een bijkomend voordeel is dat je heel gericht aanpassingen kunt laten doen of vragen kunt stellen over de code, zonder dat je de documentatie of websites als Stack Overflow hoeft door te spitten. Het is geen verrassing dat laatstgenoemde website met fors dalende bezoekersaantallen te maken heeft. Ook andere taken, zoals het schrijven van de documentatie, zijn snel geregeld.

In dit artikel gaan we een eenvoudig programma maken met AI, zodat je een goed beeld hebt van de workflow. We gebruiken drie verschillende tools. We starten met het vertrouwde ChatGPT, al kun je ook bijvoorbeeld voor Claude of Gemini kiezen. Daarna gaan we met Aider in combinatie met Git aan de slag. Daarmee werk je ‘samen’ aan programmacode via de opdrachtprompt, in ons voorbeeld binnen het vertrouwde Visual Studio Code. Tot slot gaan we met de Windsurf Editor aan de slag, een completere grafische ontwikkelomgeving met geïntegreerde AI-features, die je van begin tot eind ondersteunt bij het maken van je programma. 

Basisbeginselen van het programmeren

Het is handig als je de basisbeginselen van een programmeertaal kent. Ook daar kan AI van nut zijn. Je kunt veel leren van de voorbeelden die worden gegenereerd. Je kunt elk detail uit laten leggen, of om meer voorbeelden vragen. Dat is heel effectief!

Ook om de basisbeginselen te leren is AI nuttig. Pas bijvoorbeeld de Pareto-methode toe. Die methode stelt dat 80 procent van de resultaten voortkomt uit 20 procent van de inspanningen. Vraag de chatbot om een plan te maken dat deze regel toepast op het leren programmeren van bijvoorbeeld Python, door te focussen op 20 procent van de concepten, tools en technieken die 80 procent van de praktische toepassingen en problemen oplossen voor een beginnende programmeur. Vraag om een gestructureerd plan dat in korte tijd resultaat oplevert, inclusief voorbeelden en kleine projecten om vaardigheden direct toe te passen.

Vraag aan ChatGPT om een leerplan op te stellen om je te helpen bij het programmeren.

ChatGPT

Chatbot

Grote taalmodellen (LLM’s) vormen de basis voor chatbots als OpenAI’s ChatGPT en Anthropics Claude, maar óók voor de tools die we hierna behandelen. Feitelijk benaderen we de chatbots in dit eerste deel van het artikel rechtstreeks, via een browser of app. De andere tools gebruiken de API van deze bedrijven. Raadpleeg eventueel voor het starten met ChatGPT deze basiscursus.

De nieuwere modellen (we gebruiken overwegend ChatGPT 4o en Claude 3.5 Sonnet) laten heel goede resultaten zien voor programmeertaken. Ze helpen uiteraard niet alleen om programmacode te schrijven maar kunnen code ook uitleggen, fouten oplossen en de documentatie schrijven. Ook kun je uitstekend brainstormen over een project of ideeën. Het is daarom, óók als je andere tools voor programmeren gebruikt, enorm praktisch om erbij te hebben! Toegang tot ChatGPT is gratis met beperkingen. Een abonnement is minder gelimiteerd en geeft vaak toegang tot nieuwere modellen (zoals o1 of o3-mini). Zo’n abonnement is niet bruikbaar voor de andere tools, die gebruiken namelijk de API waarvoor je aparte credits moet aanschaffen.

Een chatbot biedt goede ondersteuning bij al je programmeervragen.

Eerste stappen

We beginnen met een eenvoudig voorbeeld en vragen aan ChatGPT om een spelletje boter-kaas-en-eieren te maken, ook wel bekend als tic-tac-toe. Hoewel het Engels soms betere resultaten kan geven, werken we voor dit artikel volledig in het Nederlands. We starten met deze prompt: “Maak een volledig functionele boter-kaas-en-eieren voor in een browser. Maak de HTML-structuur, voeg CSS-stijlen toe en implementeer de JavaScript-logica. Maak een scheiding tussen HTML, CSS en JavaScript. Zorg dat het programma responsief is zodat het bij elke schermgrootte werkt.”

ChatGPT genereert de gevraagde code. Je kunt individueel de HTML, CSS en JavaScript kopiëren. Om het te proberen, kun je alles plakken op websites als www.jsfiddle.net en www.codepen.io. Voor dit voorbeeld hebben we bij JSFiddle een projectpagina aangemaakt. We gaan dit voorbeeld in de volgende stappen verder verbeteren, steeds met links naar de verbeterde versie.

De eerste versies van het spel boter-kaas-en-eieren.

Geluiden toevoegen

We vragen ChatGPT om het programma aan te passen, zodat er een geluid wordt afgespeeld bij elke zet. ChatGPT voegt daarop een audio-element toe aan de HTML-code. Het past ook het script aan om dit aan te roepen bij elke zet. Je moet nog wel zelf het mp3-bestand plaatsen in de uiteindelijke programmamap of een volledige link naar het mp3-bestand invullen in de HTML-code:

<audio id="move-sound" src="muisklik.mp3"></audio>

Er zijn overigens veel websites waar je leuke geluidseffecten kunt vinden die je vrij kunt gebruiken, waaronder Pixabay. Op deze pagina zie je onze aangepaste versie.

De aangepaste HTML-code bevat een verwijzing naar een mp3-bestand.

Computertegenstander

We vragen ChatGPT vervolgens om een slimme computertegenstander toe te voegen, waarbij aan het begin van het spel wordt gekozen wie er mag beginnen. Via deze webpagina kun je deze versie zien. De computertegenstander blijkt in eerste instantie overigens helemaal niet zo slim, waardoor je makkelijk je potjes wint. Maar dat is snel opgelost. Na ons verzoek om de computertegenstander slimmer te maken, controleert het programma voortaan eerst op mogelijke winnende zetten en blokkeert het de tegenstander indien nodig. Als er geen direct winnende of blokkerende zetten zijn, kiest het een willekeurige lege cel. Deze slimmere versie kun je hier bekijken.

Het aangepaste script op een canvas in ChatGPT.

Uiterlijk verfraaien

Als laatste hebben we gevraagd het uiterlijk wat mooier te maken. Hierbij wordt voornamelijk de CSS-code aangepast om de visuele stijl van het spel te verbeteren. Het resultaat is geslaagd: ChatGPT geeft de achtergrond een mooi kleurverloop. Ook zijn de stijlen van de knoppen en speelvelden aangepast. Het levert een veel moderner en aantrekkelijker uiterlijk op.

Je kunt ChatGPT uiteraard steeds vragen om het script of een deel daarvan uit te leggen. Ben je het overzicht over de wijzigingen kwijt, dan kun je uiteraard ook vragen om de laatste HTML-code in te zien, of de laatste versie van het script. Eventueel op een canvas. Toch misten wij in ChatGPT soms wat overzicht en is het bovendien lastig om een stapje terug te doen als een aanpassing niet het gewenste resultaat oplevert. Dit zijn zaken die we in het volgende deel gaan aanpakken met Aider.

De gemoderniseerde versie van boter-kaas-en-eieren.

Contextvenster bij een taalmodel

Bij het werken met een groot taalmodel ofwel een Large Language Model (LLM) zijn er enkele technische beperkingen. Een daarvan is het contextvenster. Dat kun je zien als de hoeveelheid tekst die het model kan onthouden, gemeten in tokens. Een token is een deel van een woord en kan ook spaties en leestekens bevatten. Gemiddeld is een token ongeveer 3 tot 4 tekens groot.

Eerdere versies van ChatGPT hadden een relatief klein contextvenster van 4096 tokens. Het kan dan niet altijd alle details onthouden van de gebruikte teksten. Tegenwoordig is het contextvenster veel groter, en onthouden de modellen gemakkelijk 128.000 tokens of meer. Dat is ongeveer een heel boek! Dat is niet alleen nuttig bij het werken met hele lange teksten of artikelen, maar ook bij programmeerwerk, waar je vaak met grote bibliotheken te maken hebt.

Aider

Opdrachtprompt

Voor grotere programmeerprojecten is het werken met een chatbot al snel vervelend en verwarrend. Veel praktischer is een tool die met jouw eigen projectbestanden werkt en zelf of samen de gewenste aanpassingen maakt. Als je geen moeite hebt met het werken met een opdrachtprompt, is Aider een uitstekende optie. Die tool helpt met het schrijven en aanpassen van code.

Aider is opensource en werkt met heel veel LLM’s samen. Hier gebruiken we de API voor Claude 3.5 Sonnet, maar je kunt ook de API van OpenAI gebruiken of een LLM die je zelf lokaal draait of elders, zoals via OpenRouter. De integratie met Git is enorm praktisch. Voor elke aangebrachte wijziging voert het een ‘commit’ uit, voorzien van een duidelijke omschrijving, zodat je achteraf een goed overzicht met alle veranderingen hebt en ook stapjes terug kunt doen. Niet alle alternatieven bieden dit en dat is vooral een gemis als er iets fout gaat en je geen idee meer hebt hoe je dat moet oplossen.

Aider werkt samen met alle gangbare LLM’s.

Voorbereiding

We willen weer laten zien hoe je het spelletje boter-kaas-en-eieren met Aider zou kunnen maken. We gebruiken het voor velen vertrouwde programma Visual Studio Code onder Windows en installeren Aider via een opdrachtprompt binnen die ontwikkelomgeving. Binnen de editor kun je uiteraard alle gegenereerde bestanden bekijken en handmatig aanpassen. Voor de installatie van Aider heb je Python nodig. Zet tijdens de installatie van Python een vinkje bij Add python.exe to PATH, zodat je Python vanuit elke map kunt aanroepen.

Installeer ook Visual Studio Code als je dat nog niet eerder hebt gedaan. Visual Studio Code biedt een mogelijkheid om Copilot als assistent te gebruiken, maar dat slaan we hier over.

Installeer ook Git, zodat versiebeheer mogelijk is. Kies tijdens de installatie van Git voor het gebruik van Visual Studio Code als standaardeditor. Verder kun je alle standaardinstellingen accepteren. Als je Python, Visual Studio Code en Git hebt geïnstalleerd, kun je door met de installatie van Aider.

Installeer Python onder Windows voordat je met Aider aan de slag gaat.

Installatie Aider

We kunnen nu Aider installeren. Open daarvoor Visual Studio Code en kies in het menu de optie Terminal / New Terminal. Verander de terminal, via de optie rechtsboven in het venster, naar Git Bash. Installeer daarna Aider met de volgende twee opdrachten:

python -m pip install aider-install
aider-install

Sluit de terminalvenster via het kruisje rechtsboven. Open dan een nieuwe terminal en wissel weer naar Git Bash. Als je Aider niet kunt aanroepen met aider zul je het PATH moeten uitbreiden met de aangegeven opdracht, zoals in het voorbeeld hieronder:

export PATH="C:\\Users\\gertj\\.local\\bin:$PATH"

Zorg dat je in dit voorbeeld voor Claude 3.5 Sonnet een API-sleutel hebt en voldoende credits om mee te beginnen (zie het kader ‘API-sleutel maken voor Claude’). Exporteer deze API-sleutel zodat Aider deze direct kan gebruiken:

export ANTHROPIC_API_KEY=sk-ant…

Maak nu een nieuwe map voor je toepassing, blader naar die map en maak een Git-repository:

mkdir tictactoe
cd tictactoe
git init .

Je kunt nu beginnen met programmeren, met de ondersteuning van Aider!

We installeren Aider om het binnen Visual Studio Code te gebruiken.

API-sleutel maken voor Claude

Bij Aider werken we zoals aangegeven met Claude 3.5 Sonnet, een populaire optie onder programmeurs. Voor toegang is een API-sleutel nodig. Ga daarvoor naar de console van Anthropic. Vul je e-mailadres in. Via e-mail ontvang je een beveiligde link waarmee je kunt inloggen. Ga dan naar Settings / API keys en klik op Create Key. Vul een naam in, bijvoorbeeld Aider, en klik op Add. Noteer de API-sleutel, deze is later niet meer zichtbaar!

Je hebt ook wat credits nodig. Ga daarvoor naar Billing en voeg credits toe met een creditcard via de optie Add Funds. Begin met een klein bedrag, zoals 10 dollar. Heb je over? Je kunt het altijd nog opmaken door een chatbot als Jan met de API te verbinden.

Via de console van Anthropic kun je een API-sleutel maken.

Programma maken

We gaan ons eerste programma maken. Zorg dat je een terminalvenster hebt geopend en bent gewisseld naar Git Bash. De assistent start je dan met de volgende opdracht:

aider --sonnet

Er wordt de eerste keer gevraagd om .aider* en .env toe te voegen aan .gitignore. Dat raden we aan! Hiermee voorkom je dat deze bestanden, vaak met wachtwoorden en dergelijke, per ongeluk in je Git-repository worden opgenomen en daardoor in potentie online komen, als je de repository via GitHub beschikbaar maakt.

Via de prompt kun je nu je opdrachten afvuren. We vragen zoals eerder om een volledig functionele en responsieve boter-kaas-en-eieren voor in een browser met de vereiste HTML-structuur, CSS-stijlen en JavaScript-logica in aparte bestanden.

Aider gaat direct aan de slag en laat heel overzichtelijk alle aanpassingen zien, met een beschrijving van de uiteindelijke functionaliteit. Het vraagt netjes of het de nieuwe bestanden mag maken (index.html, styles.css en script.js) en daarna of het deze mag openen in een browser. Het spel is in deze eerste versie volledig responsief met een duidelijke gebruikersinterface, houdt de speelstatus bij, detecteert wanneer iemand wint of als het een gelijkspel is, heeft een knop om het spel opnieuw te starten en is helemaal in het Nederlands. Een goed begin!

Aider heeft het programma voor ons uitgewerkt.

Aanpassingen maken

We vragen opnieuw in natuurlijke taal om wijzigingen te maken. De workflow is erg prettig. Aider geeft eerst aan welke bestanden waarschijnlijk moeten worden gewijzigd. Voor het geluid stelt het bijvoorbeeld wijzigingen in index.html en script.js voor. Dan vraagt Aider of het deze bestanden mag toevoegen aan de chat.

Als de radartjes zijn uitgedraaid, na interactie met Claude, geeft Aider heel nauwkeurig aan welke regels in welke bestanden moeten worden gewijzigd. Ook geeft Aider aan dat je een mp3-bestand genaamd move.mp3 in dezelfde map moet plaatsen.

We vragen Aider daarna ook om een slimme computertegenstander toe te voegen. Die is meteen heel slim en probeert direct te winnen als dat kan, blokkeert winnende zetten van de tegenstander, probeert het centrum te veroveren en kiest anders voor hoeken of willekeurige zetten.

Tot slot vragen we Aider om het programma te verfraaien met een moderner uiterlijk. Dat levert een flinke metamorfose op. Bekijk hier het resultaat.

Via een comfortabel proces maakt het alle gewenste aanpassingen.

Kosten voor werken met Aider

We hebben tijdens het werken met Aider continu de credits in de gaten gehouden. We controleerden dit via de console bij Anthropic, maar Aider zelf toont ook bij elke actie welke kosten het heeft gemaakt. Voor de meeste aanpassingen gaat het om zo’n 5 tot 11 dollarcent. In totaal heeft het programma ongeveer 0,23 dollar (circa 0,22 euro) gekost. Het hangt er voornamelijk vanaf hoeveel tokens er nodig zijn, wat weer samenhangt met de omvang van de bestanden die aan de chat worden toegevoegd.

Integratie met Git

De standaard integratie met Git biedt veel voordelen. Als Aider aanpassingen maakt aan een bepaald bestand zal het in Git een heldere beschrijving toevoegen aan de zogeheten commit. In Visual Studio Code kun je deze historische aanpassingen eenvoudig terugzien. Klik daarvoor op een bestand en open in de balk aan de linkerkant Timeline. Zorg dat de filterinstelling is ingesteld op Git History.

Nu zie je de commit-geschiedenis van het geselecteerde bestand. Door op een specifieke commit te klikken, kun je de aangebrachte wijzigingen bekijken. Binnen Aider zijn er ook nog wat trucjes. Zo kun je met /diff zien wat de laatste veranderingen zijn. Met /undo kun je die eenvoudig ongedaan maken.

We hebben de repository op GitHub gezet. Ook hier kun je alle veranderingen bekijken. Open daarvoor een bestand, zoals script.js, en ga dan rechtsboven naar History. Hier zie je de verschillende wijzigingen. Als je op een van de aanpassingen klikt, zie je netjes welke veranderingen in de code zijn gemaakt.

Je kunt handig zien welke historische wijzigingen zijn aangebracht in bestanden.

Git en GitHub

Aider gebruikt een git-repository. Sommige mensen verwarren dit met GitHub. Je kunt met Git prima alleen een lokale repository maken, op het systeem waarop je met Aider werkt. Optioneel kun je deze repository met GitHub verbinden, zodat je in feite een kopie in de cloud hebt. Dat is voor jezelf wel heel praktisch, omdat je veel makkelijker de wijzigingen kunt bijhouden en bestuderen. En je kunt ook met anderen samenwerken aan code.

Ook interessant om te lezen: GitHub Codespaces: altijd de juiste tools bij de hand

We hebben de repository gedeeld met GitHub, zodat je alle veranderingen kunt inzien.

Windsurf Editor

 Complete ontwikkelomgeving

Zoek je een completere ontwikkelomgeving met geïntegreerde AI, dan zijn Cursor AI en Windsurf Editor twee populaire opties. Cursor AI is een gevestigde speler, maar krijgt steeds meer concurrentie van het nieuwere Windsurf Editor. Beide ontwikkelteams blijven verbeteringen doorvoeren om niet voor elkaar onder te doen.

Beide programma’s zijn bovendien klonen van Visual Studio Code, de bekende editor van Microsoft die we ook voor Aider hebben gebruikt. Daarom lijken ze in veel opzichten op elkaar. Het kan handig zijn om verschillende thema’s te gebruiken als je ze naast elkaar gebruikt, zodat je ze uit elkaar kunt houden.

Windsurf Editor werkt met een ingebouwde assistent genaamd Cascade.

Cascade

We hebben ook in Windsurf geprobeerd om het spelletje boter-kaas-en-eieren uit dit artikel te maken. De assistent in Windsurf Editor heet Cascade; via het Cascade-deelvenster kun je hem direct aan het werk zetten. Een leuk detail is dat niet alleen code wordt gegenereerd, maar dat er ook veel aanvullende acties voor je worden uitgevoerd, zoals het aanmaken van een map voor je project en voor de geluiden, en het maken van een mp3-bestand.

Bij elke stap kun je zien welke bestanden worden aangepast en de voorgestelde wijzigingen controleren en bevestigen. Je hoeft niet, zoals bij Aider, zelf een API-sleutel te regelen voor toegang. Je gebruikt steeds het model van Cascade en de administratieve kant wordt via je account geregeld, op basis van credits (zie volgende paragraaf). Zo’n diepere integratie is heel praktisch. Toch heeft de workflow veel overeenkomsten met Aider.

Via een deelvenster kun je een conversatie met Cascade voeren.

Werken met credits

Windsurf werkt met credits voor verschillende taken. Zo worden User Prompt-credits voor elke interactie met de assistent gebruikt en Flow Action-credits voor alle acties die worden uitgevoerd. Als je de limiet bereikt voor het premiummodel, wordt overgeschakeld naar het basismodel. De proefperiode van 14 dagen geeft je ruim voldoende credits om het voorbeeldprogramma uit dit artikel te maken. Sterker nog, je hebt ongeveer vijftien keer meer credits dan nodig, dus je kunt ook grotere en complexere programma’s proberen te maken.

Buiten die proefperiode is, om het premiummodel te gebruiken, een upgrade naar de Pro-versie bijna onvermijdelijk (ca. 18 euro per maand). Je hebt dan wel elke maand een ruime hoeveelheid credits en kunt vrij voordelig credits bijkopen.

Windsurf Editor werkt met een systeem van credits.

Beste optie voor hobbyprogrammeur?

Over het algemeen werkt het programmeren met een chatbot zoals ChatGPT goed. Voor losse functies of snippets werkt het zelfs uitstekend. Maar het is lastig om het overzicht te behouden over de gegenereerde code en eventuele aanpassingen, zeker als het om wijzigingen in meerdere bestanden gaat.

Aider en Windsurf Editor hebben een fijnere workflow, omdat ze de lokale bestanden direct voor je wijzigen, eventueel meerdere tegelijkertijd. Wat kosten betreft is Aider waarschijnlijk interessanter voor de hobbyprogrammeur die af en toe een project oppakt. Je kunt ad-hoc wat credits bijkopen of eens een ander model proberen, lokaal of via bijvoorbeeld OpenRouter. Het opensource DeepSeek R1 bijvoorbeeld. Je kunt bovendien elke ontwikkelomgeving kiezen, terwijl Windsurf Editor volledig op Visual Studio leunt. De integratie met Git ook een praktisch voordeel van Aider.

▼ Volgende artikel
Zo deel je je keuken handig en logisch in
© Andy Dean Photography
Huis

Zo deel je je keuken handig en logisch in

Of je nu graag uitgebreid kookt of elke avond snel klaar wilt zijn: een slimme keukenindeling maakt het verschil. Alles moet logisch op zijn plek staan, zodat je moeiteloos overal bij kunt en na afloop ook weinig tijd kwijt bent aan opruimen.

Je keuken slim indelen? Wij hebben tips voor:
  • Vaatwasser, gootsteen en vuilnisbak
  • Werkblad en kookplaat
  • Koelkast
  • Neem de keuken-driehoek als uitgangspunt
  • Kies de optimale werkhoogte
  • Opbergruimte

Lees ook: Fornuis op maat: kies het aantal pitten dat bij je past

Vaatwasser, gootsteen en vuilnisbak

Heb je plannen voor een nieuwe keuken? Denk dan nu al na over welke slimme keuzes je kunt maken met de indeling. Plaats bijvoorbeeld de vaatwasser, de spoelbak en de afvalemmer dicht bij elkaar. Je hoeft dan nooit ver te lopen met vieze borden en je kunt ze makkelijk leegschrapen, eventueel afspoelen en direct inruimen. Staat de afvalbak in een kastje direct naast de vaatwasser? Let er dan op dat je het deurtje nog goed kunt openen als de deur van de vaatwasser omlaag staat. Dat werkt makkelijker bij het inruimen. Plaats verder de vaatwasser niet direct tegen een zijmuur. Tijdens het inruimen loop je dan sneller kans op spetters tegen de muur.

Werkblad en kookplaat

Het werkblad is meer dan alleen een plek om iets op te zetten. Je gebruikt het om te snijden, te mixen, spullen neer te leggen en borden op te scheppen. Zorg daarom dat je voldoende vrije werkruimte overhoudt – dus niet alles volbouwen met apparatuur. Plaats de spoelbak of kookplaat liever niet op een hoek. Je hebt aan beide kanten plek nodig, zodat je je handen vrij kunt houden en spetters opvangt. Reken aan weerszijden minimaal veertig centimeter. Dat oogt niet alleen rustiger, het werkt ook prettiger. Handig om te weten: bij je keukenspecialist wordt hiervoor vaak de term aflegruimte gebruikt. En nog even over de kookplaat: plaats die bij voorkeur niet pal naast de koelkast of een hoge kast; dat geeft weinig bewegingsvrijheid en maakt het lastig om met meerdere mensen tegelijk in de keuken te staan.

©Olga Yastremska and Leonid Yastremskiy

Koelkast

Een koelkast gebruik je vaker dan je denkt – gemiddeld zo'n 35 keer per dag. Zet 'm daarom op een plek waar je er makkelijk bij kunt, ook als je vanuit de woonkamer even snel iets wilt pakken. Zet de koelkast liever niet helemaal achterin of op een plek waar je niet vanzelf langsloopt; dat is al snel onhandig in het dagelijks gebruik. Let ook op de temperatuur rondom de koelkast. Zet hem niet naast een oven, radiator of op een plek waar veel zonlicht komt. Kan het echt niet anders, zorg dan voor een isolerende tussenplaat en houd minstens drie centimeter ruimte vrij tussen warmtebron en koelkast.

Gebruik de keuken-driehoek

In de basis draait een keuken om drie functies: koken, spoelen en koelen. Je fornuis, gootsteen en koelkast vormen samen een denkbeeldige driehoek. Als de afstanden tussen deze drie goed gekozen zijn, werk je prettiger. Staan ze te ver van elkaar, dan loop je onnodig veel. Staan ze te dicht bij elkaar, dan dan wordt het al snel krap en onhandig. Een keukenspecialist kan helpen bij het vinden van een goede verhouding, maar je merkt het zelf vaak ook al als iets net niet lekker werkt.

Optimale werkhoogte

Ook de hoogte van je werkplekken telt mee. Een oven op armhoogte is een stuk prettiger dan op kniehoogte, zeker als je vaak bakt. Het voorkomt bukken. Heb je een kleine keuken? Kies dan voor een compacte oven of voor een fornuis met geïntegreerde oven. Datzelfde geldt voor de vaatwasser: als je die wat hoger plaatst, spaar je je rug en knieën. Voor de kookplaat geldt een andere regel: meet de afstand van je onderarm tot het werkblad. Is die ongeveer twaalf centimeter, dan zit je goed qua houding en belast je je schouders niet onnodig.

Apparatuur wat hoger plaatsen (als dat kan) heeft nog een voordeel. Wanneer je kleine kinderen hebt rondlopen, kunnen die er minder makkelijk bij. Wel zo veilig!

©lev dolgachov

Opbergruimte

Tot slot: denk na over hoe je spullen opbergt. Onderkastjes bieden veel ruimte, maar vragen vaak veel van je rug. Bovenkastjes kunnen juist weer te hoog zijn. Een buffetkast biedt uitkomst: wat je dagelijks gebruikt zet je op ooghoogte, wat minder vaak nodig is kan best wat lager of juist hoger.

Slim indelen = een fijnere keuken!

Een goede keuken draait niet alleen om de juiste apparatuur, maar vooral ook om slimme keuzes die het koken makkelijker maken. Denk na over looproutes, werkhoogtes en voldoende bewegingsruimte. Positioneer alles op logische plekken, zorg voor een werkblad met voldoende vrije ruimte en let op kleine details zoals de draairichting van kastdeurtjes. Daarmee wordt de keuken (nog meer) het hart van je huis!