ID.nl logo
Zo scheid je het IoT van je thuisnetwerk
© Reshift Digital
Huis

Zo scheid je het IoT van je thuisnetwerk

Het Internet of Things heeft op het gebied van veiligheid geen goede reputatie. Om dergelijke apparaten dan zomaar te mixen met je eigen computers en tablets, zorgt voor een groot risico. Een veilige aanpak is om je IoT- en domotica-apparaten te scheiden van de rest van het thuisnetwerk, iets wat je op verschillende manieren kunt doen. Zo kun je je eigen IoT beveiligen.

Het probleem met domotica en IoT is natuurlijk veiligheid. Alle fabrikanten zijn nu eerst zo druk bezig om toepassingen te vinden voor hun IoT-apparaten, dat ze niet nadenken over de veiligheid ervan. Een koelkast of wasmachine met Android, of zelfs een broodrooster aangesloten op internet. Deze apparaten vormen potentie enorme veiligheidsproblemen als ze verbonden worden met wifi. De grootste ddos-aanval tot nog toe was bijvoorbeeld niet mogelijk geweest zonder alle met het internet verbonden camera’s.

Waarom is het Internet of Things dan zo onveilig? Daar zijn verschillende redenen voor. Veel van die apparaten hebben geen automatische updates. Dat is op z’n zachtst gezegd niet zo’n goed idee voor een apparaat dat met internet verbonden is. Veel van die apparaten worden bovendien gebouwd door start-ups; door nieuwe bedrijven die veiligheid niet hoog op de prioriteitenlijst hebben staan. De standaardinstellingen zijn vaak onveilig en moeten handmatig veranderd worden, iets wat maar weinig gebruikers überhaupt weten, laat staan dat ze het doen. Sowieso is het niet eenvoudig om dat soort apparaten goed te beveiligen, dat kost veel extra moeite van de fabrikant. Bovendien komt het volgende product alweer snel uit, dus waarom zou de fabrikant de oudere versie dan nog van updates voorzien? In veel gevallen gebeurt dat dan ook niet.

Daarom laten we je in deze masterclass zien hoe je voor je domotica- en IoT-apparaten een gescheiden netwerk op kunt zetten. We beginnen eerst met een gastnetwerk, voor als je een enkele router hebt of veel draadloze apparaten. Daarna laten we zien hoe je een firewall kunt gebruiken, en hoe je een aparte router kunt gebruiken om je slimme apparaten mee te verbinden. Na die stap pakken we het helemaal professioneel aan met een apart vlan (oftewel virtual lan) voor je IoT-apparaten. Als laatste bekijken we nog een andere oplossing, namelijk speciale routers bedoeld voor het scannen van internetverkeer gericht op veiligheid van IoT.

01 Gastnetwerk opzetten

Een van de eenvoudigere stappen om je IoT-apparaten te beveiligen en te scheiden is door een gastnetwerk op te zetten. Op die manier splits je het internetverkeer. Dat heeft als voordeel dat je het gastnetwerk op softwareniveau kunt scheiden en beter kunt beheren. Via een gastnetwerk is het namelijk niet mogelijk om bij apparaten op het lokale netwerk te komen of bij andere wifi-apparaten. Bij sommige routers kun je zelfs limieten instellen op het gastnetwerk. Dat is handig, want zo voorkom je dat de IoT-apparaten opeens al je bandbreedte in beslag nemen. Let er bij het opzetten van een gastnetwerk op dat al je eigen apparaten verbinding maken met het normale wifi-netwerk. Stel alleen de ‘risico-apparaten’ zo in dat ze verbinding maken met het gastnetwerk. Als je dan toch verbinding wilt maken met een van je IoT-apparaten, dan hoef je alleen te wisselen van wifi-netwerk. Of je houdt een oude telefoon of tablet bij de hand die je wel permanent onderdeel maakt van het gastnetwerk.

Je schakelt het gastnetwerk in door in te loggen in je router, als die de functie ondersteunt. Zoek daarvoor even het gateway-adres van je router (zie kader ‘Inloggen in je router’). Eenmaal ingelogd, zoek je in je router tussen de opties voor het draadloze netwerk een optie als Gastnetwerk (guest network). Schakel die optie in. Zorg ervoor dat je een wachtwoord instelt op het gastnetwerk en het gastnetwerk beveiligt met wpa2-aes.

©PXimport

Inloggen in je router

Je logt als volgt in op je router: heb je een Netgear-router, dan typ je in de adresbalk simpelweg http://routerlogin.com. Log dan in met je gebruikersnaam en wachtwoord. Weet je die niet? Raadpleeg dan even de handleiding. Voor slimme Linksys-routers ga je naar http://myrouter.local. Voor TP-Link ga je naar http://192.168.1.1 in je browser en voor Asus typ je in http://router.asus.com. Voor een Synology-router kun je naar http://router.synology.com. Voor andere routers of modem-routers, moet je op zoek naar het gatewayadres. Dat vind je door rechts te klikken op de Startknop in Windows, kies voor Opdrachtprompt en typ ipconfig. Zoek naar de interface waarmee je verbonden bent. In de lijst zie je Default Gateway. Typ dat adres in de browser in.

02 AP Isolation & upnp

Handig is de optie AP Isolation bij een gastnetwerk. Met AP Isolation kunnen de apparaten op het gastnetwerk elkaar niet zien. Als op die manier dan een van je apparaten gehackt en besmet wordt met malware, kan dat zich moeilijker verspreiden naar de andere IoT-apparaten. Zet daarom bij het gastnetwerk de optie AP Isolation of Wireless isolation aan. Bij sommige routers kun je in het gastnetwerk upnp aan- of uitzetten. Met upnp zijn IoT-apparaten zelf in staat om poorten door te sturen, maar upnp is in veel routers niet heel veilig. Het beste laat je het uit staan en forward je zelf de poorten door in je router. Raadpleeg per apparaat de handleiding en bekijk welke poorten open moeten. In de router ga je dan naar Portforwarding of naar iets als Apps en games. Zorg er dan gelijk voor dat elk IoT-apparaat een statisch ip-adres heeft.

©PXimport

03 DD-WRT firewall

Een andere oplossing waar je voor kunt gaan is om een firewall te gebruiken op je router. Je stelt dan een aantal firewallregels in, waardoor je IoT-apparaten alleen maar met de buitenwereld mogen communiceren en niet met het lokale netwerk. Veel consumentenrouters hebben hiervoor niet heel uitgebreide mogelijkheden. Je bent doorgaans het beste af met een router voorzien van DD-WRT, dan is het mogelijk om iptables te gebruiken, waarmee je veel meer configuratiemogelijkheden hebt dan normaal. Voordat je hiermee aan de slag gaat, stel je een statisch ip-adres in voor al je IoT- en domotica-apparaten. Daarvoor ga je in DD-WRT naar Services / Services / Static Leases. Vervolgens vul je het mac-adres in van het apparaat, een hostnaam en het gewenste ip-adres. Bij Client Lease Time vul je niets in, zodat dat apparaat altijd dat ip-adres zal krijgen. Scrol naar onderen en sla de wijzigingen op.

©PXimport

04 DD-WRT ssh

Vervolgens is het nodig om ssh-toegang in te schakelen in je router. In DD-WRT ga je daarvoor naar Services / Services. Bij de sectie Secure Shell schakel je SSHd in. Je kunt er dan voor kiezen om wachtwoordautorisatie in te schakelen. Het alternatief is autorisatie met een publiek-privé-sleutelpaar. Zolang je de ssh-poort niet openzet voor de buitenwereld en als je zodra je klaar bent ssh niet vergeet uit te zetten, kan het wel even met wachtwoordautorisatie.

Download dan PuTTY voor Windows. Voer het gedownloade bestand uit. Bij Host Name voer je het ip-adres van je router in. Klik dan op Open. Typ dan bij Username de gebruikersnaam root en bij wachtwoord het wachtwoord dat je gebruikt om in de router in te loggen. Op sommige andere routers is het ook mogelijk om ssh-toegang te verkrijgen, bijvoorbeeld op de routers van Synology. Zolang de router iptables gebruikt, zit je goed.

©PXimport

05 DD-WRT firewallregels

In SSH, voer je dan het volgende commando in:

iptables -t filter -I FORWARD -s 192.168.1.xx -d 192.168.1.0/24 -j DROP

Vervang 192.168.1.xx door het correcte ip-adres van het apparaat dat je de toegang tot je lan wilt ontzeggen. We gaan ervan uit dat je router ip-adressen uitdeelt in 192.168.1.0 reeks. Is dat niet het geval, wijzig het commando hierboven dan, bijvoorbeeld naar 10.1.0.0/24. Om te controleren welke regels er op dit moment actief zijn in iptables, voer je het volgende commando uit: iptables -L

Als je een regel weer wilt verwijderen uit de firewall, doe je dat op basis van wat die doet. Stel je wilt de bovenstaande regel verwijderen, dan voer je het commando uit:

iptables -D FORWARD -s 192.168.1.xx -d 192.168.1.0/24 -j DROP

©PXimport

Alternatief: ouderlijk toezicht

Niet elke router heeft ssh-toegang of kan DD-WRT draaien. Als je dan toch zelf wát actie wilt ondernemen, zou je nog op z’n minst ouderlijk toezicht in kunnen schakelen. Routers met die functie hebben dan de optie om kwaadaardige en phishingwebsites te blokkeren. Als je die filters toepast op je IoT-apparaten, heb je in ieder geval één vorm van bescherming. Sommige apparaten kun je bovendien alleen lokaal gebruiken. Je kunt ze dan aan het netwerk hangen en via ouderlijk toezicht in de router alle verbindingen met de buitenwereld ontzeggen. Dan ben je ook veilig.

©PXimport

06 Twee extra routers

Een gastnetwerk is een goede oplossing, maar in de praktijk zit er een aantal haken en ogen aan. Het werkt sowieso alleen met wifi, niet voor bedrade apparaten. Ook hebben sommige routerfabrikanten het gastnetwerk niet (veilig) geïmplementeerd. Het probleem is soms dat je het gastnetwerk niet kunt versleutelen met wpa2-aes, maar dat je een open netwerk opzet en dan eenmaal in een portal een wachtwoord in moet voeren om verbinding te maken. Dat is onveilig, want dan kan iedereen met het verkeer van je netwerk meekijken.

Een veiligere oplossing is om één of twee extra routers te gebruiken. De eerste situatie is dat we ervan uitgaan dat je een modem-router (in één apparaat) hebt van je provider plus nog twee extra routers. Dan kun je het beste je netwerk scheiden. Wat je dan doet, is dat je je twee routers aansluit op je modem-router van je provider. Normaal zouden we je dan aanraden om de DMZ-modus in te schakelen, maar die kan het verkeer maar naar één host doorsturen. In plaats daarvan schakel je in beide routers de firewall uit. Zolang de modem-router dan een actieve firewall heeft, is er niets aan de hand. Anders is het namelijk nodig om elke poort twee keer door te sturen. Vervolgens hang je al je IoT-apparaten aan de ene router en je eigen netwerkapparaten aan de andere. Op die manier heb je een gescheiden netwerk, waarbij de IoT-apparaten niet bij je lokale apparaten kunnen.

07 Een extra router

Als je twee routers hebt of een router en een modem-router, dan kun je een vergelijkbaar resultaat behalen door de routers op elkaar aan te sluiten. De wan-poort van de achterste router (doorgaans je eigen router) sluit je aan op een lan-poort van de voorste router (vaak de router van je internetprovider). Belangrijk is dan dat de twee hun eigen dhcp-servers en adresruimte hebben. Dat betekent dat de ene router bijvoorbeeld ip-adressen uitdeelt in de ruimte 192.168.1.1 tot en met 192.168.1.128 en de andere in 192.168.2.2 tot en met 192.168.2.128. Die twee adresruimtes mogen niet gelijk zijn. Daarvoor log je in op een van de routers en zoek je naar DHCP. Daar vind je welke ip-adressen de router uitdeelt. Je kunt bijvoorbeeld de x in 192.168.x.0 wijzigingen naar een willekeurig getal in beide routers.

Als je dat eenmaal ingesteld hebt, is het belangrijk dat je de IoT-apparaten op de ‘voorste’ router aansluit. Apparaten aangesloten op de voorste router kunnen niet bij de apparaten op de router erachter, omdat die router de adressen niet gaat zoeken in die tweede router maar bij zichzelf, en die niet kan herleiden. De apparaten aangesloten op de tweede of achterste router kunnen wel bij de apparaten in de eerste router, maar alleen als je dan het ip-adres uit je hoofd weet. De achterste router is dus beschermd tegen de IoT-apparaten vooraan en geschikt voor je eigen apparaten. Je kunt dan op elke router de wifi-netwerken opzetten zoals je zelf wilt.

08 Vlan

Als je het echt professioneel aan wilt pakken, dan wordt het tijd om te kijken naar vlan’s. Een vlan, virtual lan, is een netwerk dat opgedeeld is in segmenten. Bij sommige routers kun je elke poort scheiden van de rest. Dat heet ‘vlan tagging’. Je geeft dan een poort een bepaalde kleur, oftewel je tagt deze. Apparaten aangesloten op de ene kleur kunnen niet communiceren met de apparaten in de andere kleur. De eenvoudigste manier om een vlan op te zetten als je router het niet ondersteunt, is met een managed switch. Die heb je al voor een paar tientjes. Let op dat je dan echt een managed switch koopt, anders kun je geen vlan aanmaken. Ons IoT-netwerk ziet er als volgt uit: aan je modem koppel je je switch. Aan je switch hang je vervolgens bijvoorbeeld twee routers: een voor IoT en een voor je eigen, veilige apparaten.

©PXimport

09 Switch-configuratie

Heb je bijvoorbeeld een managed Netgear-switch, zoek dan het ip-adres van de switch in de router door te kijken bij aangesloten apparaten. Voer dat adres in je browser in en log in op de webinterface van de switch. Sommige goedkopere managed switches hebben overigens geen webinterface, maar beheer je via een programma in Windows. Daarna ga je naar het tabblad VLAN / Advanced. Standaard is elke poort lid van VLAN 1. Maak een nieuwe vlan door een VLAN ID in te vullen. Kies daarvoor een willekeurig getal en een VLAN Name, bijvoorbeeld IoT-netwerk. Klik op Add. Doe dat nog een keer voor je eigen netwerk. Ga nu naar de optie VLAN Membership. Kies hier je net aangemaakte VLAN ID. Je ziet nu bij de poorten U of T. U betekent ‘untagged’, t betekent ‘tagged’. Kies dan een poort die je wilt gebruiken voor je IoT-netwerk en klik op Apply. Doe dat daarna nog een keer voor je eigen netwerk. Je kunt nu de interface verlaten.

Nu pak je je twee routers erbij en sluit je die aan op de poorten die je net hebt gekozen. Het verkeer tussen beide is nu compleet gescheiden. Je kunt de routers daarna zoals normaal opzetten als twee losse netwerken.

Router kiezen

Als je op zoek bent naar een router en al veel slimme apparaten in huis hebt, denk dan aan de volgende aspecten. Belangrijk bij een router die goed is voor IoT, zijn de configuratiemogelijkheden. Je wilt veel opties en mogelijkheden om je netwerk te kunnen configureren en te beveiligen. Dan zit je wel al snel in het wat hogere en duurdere segment van de routermarkt. Een belangrijk ander punt kan zijn om te controleren op ondersteuning voor DD-WRT of OpenWRT. Je vindt een lijst met DD-WRT-ondersteuning hier terwijl je hier kunt kijken voor OpenWRT-ondersteuning. DD-WRT kan in veel gevallen vlan’s aanmaken, indien je router een Broadcom-chip bevat. Dan heb je geen extra hardware meer nodig daarvoor en sla je twee vliegen in een klap. Een lijst met routers die in ieder geval vlan ondersteunen vind je hier.

Extra veiligheidsmaatregelen

Zorg ervoor dat elke router in je netwerk goed is beschermd. Controleer regelmatig op updates en blijf op de hoogte van beveiligingsnieuws van de fabrikant. Verander het wachtwoord van de beheerdersinterface van je router. Ook stel je je router zo in dat je alleen toegang kunt krijgen tot de beheerdersinterface als je verbonden bent met een kabel in plaats van via wifi, en dat deze niet extern toegankelijk is. Verder is een belangrijke wijziging om wps uit te zetten, want dat is toch alleen maar een beveiligingslek, en schakel ook upnp uit, want dat is in veel routers een (alhoewel handige) onveilige functie. Je kunt verschillende veiligheidstests uitvoeren met Shields UP!, dat je vind hier. Zo kun je bijvoorbeeld controleren of er poorten open staan.

Extra veilige routers

Het nadeel van alle tot nu toe besproken oplossingen is dat je inlevert op gebruiksvriendelijkheid. Voor een gastnetwerk, aparte routers, firewallregels of voor vlan’s is het nodig om steeds op z’n minst één cross-netwerkapparaat te hebben zodat je toch nog bij je IoT-apparaten kunt. Je kunt het ook anders aanpakken, in de vorm van een extra apparaat dat al je andere apparaten in het netwerk gaat scannen of dat een apart, beveiligd netwerk opzet. Veel beveiligingsbedrijven erkennen de dreiging van IoT en komen daarom met eigen oplossingen. We beschrijven een paar extra veilige producten.

10 BitDefender BOX

Een van de eerste apparaten daarvan is de BitDefender BOX. Deze router is specifiek gericht op IoT-veiligheid. Fijn is dat je meteen licenties krijgt voor internetsecurity om je Windows-, Android- en macOS-apparaten lokaal mee te beveiligen. De BOX sluit je aan op je bestaande router of zet je apart op als beveiligd netwerk. Sommige routers kunnen automatisch geconfigureerd worden, maar niet alle. Eenmaal opgezet, kun je de BOX beheren via een app. Wat betreft veiligheidsfuncties worden kwaadaardige websites automatisch geblokkeerd in de router. Bovendien scant de router het netwerk op kwetsbaarheden en zal het je daarvan automatisch op de hoogte stellen. De BOX is nog niet beschikbaar in Europa.

©PXimport

11 F-Secure Sense

Een andere oplossing biedt F-Secure met Sense. Deze oplossing komt in de zomer dit jaar beschikbaar in Europa. Sense scant net als de BOX zowel binnenkomend als uitgaand verkeer en analyseert het, bedreigingen worden geblokkeerd op basis van de reputatie en het gedrag. Handig is dat Sense meteen een extraatje biedt: het blokkeert namelijk ook trackers op het internet en beidt daardoor meer privacy. De noodzaak voor standaard beveiligingssoftware wordt kleiner: Sense blokkeert al malware, virussen, spyware, adware en phishing op alle apparaten in huis. Je kunt Sense aansluiten op een bestaande router of los gebruiken.

©PXimport

12 Norton Core

Op de CES 2017 kondigde ook Symantec de securityroutermarkt te gaan betreden, met de Norton Core-router. Deze router heeft een opvallend ontwerp. Norton Core biedt bescherming tegen alle typen malware, maar ook tegen netwerkaanvallen en het biedt een veiligheidsscore voor je netwerk. Net als de Sense van F-Secure komt de Core in de zomer beschikbaar, maar voorlopig alleen nog in de Verenigde Staten.

©PXimport

▼ Volgende artikel
SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?
© arinahabich
Huis

SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?

Waarom start een computer met een SSD binnen enkele seconden op, terwijl een oude harde schijf blijft ratelen? Het vervangen van een HDD door een SSD is de beste upgrade voor een trage laptop of pc. We leggen in dit artikel uit waar die enorme snelheidswinst vandaan komt en wat het fundamentele verschil is tussen deze twee opslagtechnieken.

Iedereen die zijn computer of laptop een tweede leven wil geven, krijgt vaak hetzelfde advies: vervang de oude harde schijf door een SSD. De snelheidswinst is direct merkbaar bij het opstarten en het openen van programma's. Maar waar komt dat enorme verschil in prestaties vandaan? Het antwoord ligt in de fundamentele technologie die schuilgaat onder de behuizing van deze opslagmedia.

De vertraging van mechanische onderdelen

Om te begrijpen waarom een Solid State Drive (SSD) zo snel is, moeten we eerst kijken naar de beperkingen van de traditionele harde schijf (HDD). Een HDD werkt met magnetische roterende platen. Dat kun je vergelijken met een geavanceerde platenspeler. Wanneer je een bestand opent, moet een fysieke lees- en schrijfkop zich naar de juiste plek op de draaiende schijf verplaatsen om de data op te halen. Dat fysieke proces kost tijd, wat we latentie noemen. Hoe meer de data op de schijf verspreid staat, hoe vaker de kop heen en weer moet bewegen en wachten tot de juiste sector onder de naald doordraait. Dit mechanische aspect is de grootste vertragende factor in traditionele opslag.

©Claudio Divizia

Flashgeheugen en directe gegevensoverdracht

Een SSD rekent definitief af met deze wachttijden omdat er geen bewegende onderdelen in de behuizing zitten. De naam 'Solid State' verwijst hier ook naar; het is een vast medium zonder rammelende componenten. In plaats van magnetische platen gebruikt een SSD zogenoemd NAND-flashgeheugen. Dat is vergelijkbaar met de technologie in een usb-stick, maar dan veel sneller en betrouwbaarder. Omdat de data op microchips wordt opgeslagen, is de toegang tot bestanden volledig elektronisch. Er hoeft geen schijf op toeren te komen en er hoeft geen arm te bewegen. De controller van de SSD stuurt simpelweg een elektrisch signaal naar het juiste adres op de chip en de data is direct beschikbaar.

Toegangstijd en willekeurige leesacties

Hoewel de maximale doorvoersnelheid van grote bestanden bij een SSD indrukwekkend is, zit de echte winst voor de consument in de toegangstijd. Een besturingssysteem zoals Windows of macOS is constant bezig met het lezen en schrijven van duizenden kleine systeembestandjes. Een harde schijf heeft daar enorm veel moeite mee, omdat de leeskop als een bezetene heen en weer moet schieten. Een SSD kan deze willekeurige lees- en schrijfopdrachten (random read/write) nagenoeg gelijktijdig verwerken met een verwaarloosbare vertraging. Dat is de reden waarom een pc met een SSD binnen enkele seconden opstart, terwijl een computer met een HDD daar soms minuten over doet.

©KanyaphatStudio

Van SATA naar NVMe-snelheden

Tot slot speelt de aansluiting een rol in de snelheidsontwikkeling. De eerste generaties SSD's gebruikten nog de SATA-aansluiting, die oorspronkelijk was ontworpen voor harde schijven. Hoewel dat al een flinke verbetering was, liepen snelle SSD's tegen de grens van deze aansluiting aan. Moderne computers maken daarom gebruik van het NVMe-protocol via een M.2-aansluiting. Deze technologie communiceert rechtstreeks via de snelle PCIe-banen van het moederbord, waardoor de vertragende tussenstappen van de oude SATA-standaard worden overgeslagen. Hierdoor zijn snelheden mogelijk die vele malen hoger liggen dan bij de traditionele harde schijf.

Populaire merken voor SSD's

Als je op zoek bent naar een betrouwbare en snelle SSD, is er een aantal fabrikanten dat de markt domineert. Samsung wordt door velen gezien als de marktleider op het gebied van flashgeheugen en staat bekend om de uitstekende prestaties van hun EVO- en PRO-series. Daarnaast is Western Digital (WD) een vaste waarde; dit merk heeft de transitie van traditionele harde schijven naar SSD's succesvol gemaakt met hun kleurgecodeerde (Blue, Black en Red) series voor verschillende doeleinden. Ook Transcend is een uitstekende keuze; dit merk staat al jaren bekend om zijn betrouwbare geheugenproducten en biedt duurzame SSD's die lang meegaan. Tot slot bieden merken als Kingston en Seagate betrouwbare alternatieven die vaak net iets vriendelijker geprijsd zijn, zonder dat je daarbij veel inlevert op stabiliteit.

▼ Volgende artikel
AI zonder programmeren: Zo bouw je je eigen chatbot
© ID.nl
Huis

AI zonder programmeren: Zo bouw je je eigen chatbot

Misschien heb je wel eens een vraag gesteld aan een AI-chatbot als ChatGPT, Microsoft Copilot of Perplexity. Maar hoe ontwerp je zelf nu zo'n chatbot? Met de juiste tools is daar zelfs weinig tot geen programmeerwerk voor vereist. We bekijken twee uiteenlopende oplossingen.

Een AI-chatbot is een digitale gesprekspartner die wordt aangedreven door kunstmatige intelligentie. Meestal is de intelligentie gebaseerd op een taalmodel dat is getraind om mensachtige gesprekken te voeren. In tegenstelling tot traditionele op regels gebaseerde chatbots, die alleen vooraf ingestelde antwoorden geven, kan een AI-chatbot vrije tekst begrijpen en ‘natuurlijke’ reacties geven.

In dit artikel kijken we naar het bouwen van een eigen chatbot die je op je desktop of mobiel kunt gebruiken en zelfs op een eigen website kunt plaatsen. We bespreken twee manieren. De eenvoudigste is een no-code chatbotplatform dat het AI-gedeelte achter de schermen afhandelt en je via een gebruiksvriendelijke interface laat bepalen hoe de gespreksflow verloopt. Typische voorbeelden zijn Chatfuel en Chatbot voor zakelijke toepassingen. Daarnaast zijn er de meer toegankelijke Poe en Coze, die we hier behandelen. Onze tweede oplossing is technischer, maar flexibeler. Daarbij gebruik je de Application Programming Interface (API) van een AI-taalmodel om de AI-functionaliteit in je eigen omgeving te integreren. Hiervoor werken we graag met de online omgeving Google Colab.

Poe

Laten we starten met een gebruiksvriendelijke optie: het no-code chatbotplatform Poe (www.poe.com). Je kunt hier ook de app voor desktop of mobiel downloaden en installeren, met vrijwel dezelfde interface en functies als in de browser. De eerste keer maak je een account aan of meld je je aan met je Google- of Apple-account. Via Bots and apps kun je met allerlei AI-chatbots praten, maar in dit geval willen we vooral een eigen chatbot maken. Concreet gaat het om het creëren van een eigen ‘persona’ binnen een gekozen AI-model. Zo’n persona kun je zien als het perspectief, de rol of identiteit die je een AI-bot meegeeft.

Klik hiervoor op Create +. Je krijgt nu verschillende opties, zoals Image generation bot, Video generation bot en Prompt bot. Wij kiezen dit laatste.

Poe bestaat ook als desktop-app en biedt toegang tot vele tientallen AI-modellen.

Creatie

Je hoeft nu eigenlijk alleen maar een onlineformulier in te vullen. We doorlopen kort de belangrijkste onderdelen. Naast het gekozen bottype moet je een naam verzinnen. Omdat deze deel uitmaakt van de url, kies je bij voorkeur een originele, korte naam in kleine letters. Voeg ook een beschrijving toe, die zichtbaar is voor gebruikers van je bot.

Bij Base bot selecteer je een geschikt AI-model, bijvoorbeeld Claude-Haiku-3, GPT-4o-mini, GPT-5 of Grok-4. Afhankelijk van het model gelden er soms beperkingen. Poe-abonnees krijgen doorgaans uitgebreidere toegang tot de duurdere modellen.

Bij Prompt beschrijf je nauwkeurig en uitgebreid hoe de bot moet reageren. De optie Optimize prompt for Previews kun je uitgeschakeld laten. Vul bij Greeting message een welkomstwoord in dat de bot bij elke start toont. Het onderdeel Advanced kun je eigenlijk ongemoeid laten, maar interessant is wel dat je bij Custom temperature het ‘creativiteitsgehalte’ van de bot kunt instellen: hoe hoger de waarde, hoe creatiever en onvoorspelbaarder.

Bij Access kies je de zichtbaarheid van je bot. Wellicht is Only people with the access link de handigste optie, waarna de url zichtbaar wordt en je deze kunt verspreiden. Klik bovenin op Edit picture en kies of ontwerp een passend pictogram. Is alles ingevuld, klik dan onderin op Publish. Je bot is nu klaar voor gebruik. Om je bot te bewerken, hoef je deze maar bij Bots and apps te selecteren en via het knopje met de drie puntjes op Edit te klikken. Ook de optie Delete is beschikbaar.

Geef duidelijk aan wat je bot precies moet doen.
GPT's van OpenAI

Binnen de omgeving van OpenAI (https://chat.openai.com) kun je ook je eigen AI-chatbots maken, de zogeheten GPT’s. Hiervoor heb je wel een plusabonnement nodig (23 euro per maand). Je bent daarbij ook beperkt tot de GPT-modellen van OpenAI, maar je kunt je creaties wel delen via een link of in de GPT-store.

In het kort werkt dit als volgt. Meld je aan en klik links op GPT’s. Klik rechtsboven op + Maken. Via Configureren stel je alles handmatig in, maar via Maken kan het ook ‘al converserend’. Beschrijf kort wat je GPT moet doen en voor wie. Laat de tool een naam en profielfoto voorstellen en beantwoord de vragen om toon en werking af te stemmen. Test je GPT in de preview en ga daarna naar Configureren, waar je naam, beschrijving, instructies en gespreksopeningen ziet. Bij Kennis kun je bestanden uploaden zodat je GPT ook informatie uit je eigen documenten haalt. Via Nieuwe handeling maken koppel je eventueel acties aan externe API’s, gebruik alleen API’s die je vertrouwt. Bevestig met Maken en bepaal hoe je je GPT deelt: Alleen ik, Iedereen met de link of GPT-winkel (in een zelfgekozen categorie). Rond af met Opslaan. Je kunt de link (https://chatgpt.com/g/<code><naam>) daarna kopiëren en verspreiden. Via GPT’s / Mijn GPT’s kun je eerder gemaakte GPT’s bewerken of verwijderen.

Je kunt ook je ook eigen ‘chatbots’ (GPT’s) ontwerpen, gebruiken en met anderen delen.

Poe biedt ook geavanceerdere mogelijkheden als een Server bot-type (waarmee je ook andere API’s kunt aanroepen). Via Knowledge base kun je verder eigen informatiebronnen toevoegen waaruit de bot kan putten. Voor complexere bots gebruiken we toch liever het no-code platform Coze (www.coze.com) dat veel extra opties kent. Meld je aan met je Google-account, klik op + Create in de linkerkolom en daarna op + Create bij Create agent.

Coze

Coze gebruikt de term agent in plaats van bot om duidelijk te maken dat je er een digitale assistent mee kunt maken die niet alleen met een AI-model antwoorden geeft, maar ook geheugen of context kan gebruiken en meerdere kanalen kan bedienen, zoals een website of een Discord-server, maar zover gaan we hier niet.

Vul een passende naam voor je bot of agent in en schrijf een korte maar duidelijke omschrijving, bijvoorbeeld “Deze bot haalt allerlei informatie uit onze eigen documenten rond computerbeveiliging.” Laat Personal geselecteerd bij Workspace en klik linksonder op het knopje om een geschikt pictogram te uploaden of klik op het sterretje om er een te laten genereren. Klik daarna op Confirm.

De start van je eigen AI-chatbot (of agent) in Coze.

Uitwerking

Je komt nu in je dashboard waar je de bot verder vorm kunt geven. Ontwerp de persona door in het linkerdeelvenster een uitvoerige omschrijving van de bot in te vullen. Optimaliseer deze omschrijving snel met het blauwe knopje Auto Optimize prompt rechtsboven. Na bevestiging met Auto-optimize werkt Coze meteen een geoptimaliseerde prompt uit voor de persona. Klik op Replace om deze te gebruiken. In het rechterdeelvenster kun je je bot direct testen. De antwoorden komen uit de kennisdatabank van het geselecteerde model (zoals GPT-4o).



Wil je dat de bot ook uit eigen bronnen put, dan moet je deze eerst uploaden. Dit doe je in het middelste deelvenster, bij

Knowledge, waar je uit Text, Table en Images kunt kiezen. Klik op het plusknopje bij bijvoorbeeld Text en daarna op Create knowledge. Selecteer Text format en geef een naam aan je informatiebundel. Je kunt data ophalen uit bronnen als Notion of Google Doc, maar wij kiezen voor Local documents om eigen bestanden te uploaden. Klik op Create and import en versleep de gewenste documenten naar het venster. Klik daarna op Next (3x) en wat later zijn je documenten verwerkt. Rond af met Confirm en met Add to Agent rechtsboven. Je vindt je informatiebundel nu terug bij Knowledge en de bot put voortaan (ook) uit deze gegevens.

Om je bot beschikbaar te maken, klik je rechtsboven op Publish en daarna op Confirm. Je kunt hem op diverse platformen publiceren, onder meer in de Coze Agent Store. Selecteer een passende categorie en bevestig met Publish.

Laat AI je helpen bij het ontwerpen van een optimale persona.

Extra's

Daarnaast biedt Coze nog diverse andere nuttige opties, zoals talrijke plug-ins. Klik hiervoor op het plusknopje bij Plugins of gebruik het A-knopje om automatisch geschikte plug-ins te laden op basis van je persona-beschrijving. Deze kun je meteen inzetten, eventueel na optimale afstelling via het tandwielpictogram.

Je kunt de functionaliteit van je bot eenvoudig uitbreiden met talrijke plug-ins.

API-sleutels

No code-platformen als Poe en Coze zijn handig, maar wil je meer flexibiliteit en schrik je niet terug voor enige basiscodering, dan werk je beter met de API van een AI-model. Deze fungeert als tussenpersoon die je script en de AI-dienst laat communiceren via een set regels en commando’s. We gaan uit van de API van OpenAI (GPT) en maken eerst een sleutel aan om de API-interface te gebruiken. Ga naar https://platform.openai.com/api-keys, meld je aan met je account (zoals Google) en klik op +Create new secret key. Geef de sleutel een naam, bijvoorbeeld aibot, en klik op Create secret key. Klik daarna op Copy en bewaar de sleutel op een veilige plek. Rond af met Done: de sleutel is nu toegevoegd. Je kunt deze hier op elk moment ook weer intrekken.

Je hebt een sleutel nodig om de API te kunnen gebruiken.

Interactie

Een snelle manier om een script te maken dat deze API aanroept, is via het gratis Google Colab (https://colab.research.google.com), een online notitieboek voor Python. Meld je aan met je Google-account, klik op + Nieuw notebook of ga naar Bestand en kies Nieuw notebook in Drive, en geef het ipynb-bestand (Interactive PYthon NoteBook) een zinvolle naam. Het notebook wordt automatisch in je Google Drive bewaard en is bereikbaar via het pictogram met de oranje cirkels.

Klik nu op + Code voor je eerste codecel, waarmee je de OpenAI-bibliotheek installeert:

!pip install openai

Voer dit uit met het pijlknopje en klik vervolgens op + Code voor de tweede cel met de volgende code:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

response = client.chat.completions.create(

    model="gpt-3.5-turbo",

    messages=[{"role": "user", "content": "Wat weet je over Haarlem( Nederlands)?"}]

)

print(response.choices[0].message.content)


Je laadt hierbij eerst de geïnstalleerde Python-bibliotheek en zet je geheime sleutel in de clientconfiguratie. Vervolgens stuur je een chataanvraag naar OpenAI en bewaar je het antwoord in de variabele ‘response’. Vervolgens haal je de tekst van het (eerste) antwoord op en druk je dit af in de uitvoer van de code-cel.

Een eenvoudige interactie tussen je script en GPT via de API.

Eigen chatbot

 We gaan nu een stap verder en maken er een heuse chatbot van die via een while-lus een doorlopend gesprek kan voeren:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

messages=[

    {"role":"system","content":"Je beantwoordt elke prompt leuk, maar correct, met een rijmschema zoals ABAB of ABBA"}]

while True:

  user_input=input("Jij:")

  if user_input.lower() in ["stop","exit","quit"]:

    break

  messages.append({"role":"user","content":user_input})

  response=client.chat.completions.create(

      model="gpt-4o",messages=messages)

  bot_reply=response.choices[0].message.content

  print("Bot:",bot_reply)

  messages.append({"role":"assistant","content":bot_reply})


Zolang de gebruiker geen stopwoord invoert, blijft de lus actief. De bot antwoordt in de stijl en taal die je zelf hebt vastgelegd in de systeemrol (zie coderegel 3). Met de methode-aanroep messages.append voeg je telkens een nieuw bericht van zowel de gebruiker (user) als de bot (assistant) toe aan de gespreksgeschiedenis.

Mocht je ergens een fout hebben gemaakt in je script, dan is de kans groot dat je via de knop Fout uitleggen nuttige feedback krijgt en met de knop Accepteren (en uitvoeren) de fout zelfs automatisch kunt laten verbeteren.

In het kader ‘Mooi gepresenteerd’ lichten we kort toe hoe je dit script bijvoorbeeld ook op een eigen webpagina kunt laten draaien.

Onze rijmende chatbot wordt wakker geschud vanuit Colab.
Mooi gepresenteerd

Je Colab-script werkt, maar het oogt niet fraai en je wilt het natuurlijk mooi gepresenteerd met anderen delen. Dit doe je het makkelijkst met Gradio, een opensource-Python-bibliotheek waarmee je snel een webinterface rond je script bouwt. Installeer en importeer daarvoor eerst Gradio in je Colab-omgeving:

!pip install -q gradio

import gradio

Via www.kwikr.nl/colabcode vind je de code (als py-bestand) waarmee je rond het Colab-script met Gradio een eenvoudige webinterface genereert. Deze verschijnt in je Colab-omgeving, maar je krijgt ook een publieke url te zien waar je de interface rechtstreeks kunt openen (https://<code>.gradio.live).

Dankzij de volgende aanroep in de laatste coderegel kunnen bezoekers van deze webpagina je chatbot-script ook als PWA-app op hun pc bewaren en starten:

demo.launch(share=True,pwa=True)

Een alternatief is deze webpagina via een <iframe>-instructie in de html-code van je eigen site op te nemen:

<iframe src=https://<code>.gradio.live></iframe>

Gradio heeft een eenvoudige webinterface gecreëerd voor ons chatbotscript.