Tuple Logo

SHARE

Begrijpen van Cross-Origin Resource Sharing (CORS)

sefa-senturk
Sefa Şentürk
2024-04-25 10:02 - 13 minutes
Software Development
DevOps
Data

Cross-Origin Resource Sharing (CORS) is een essentiële webtechnologie die noodzakelijk is geworden vanwege de complexiteit van moderne webapplicaties. In tegenstelling tot traditionele webapplicaties die op één server worden gehost, halen moderne webapplicaties bronnen op van meerdere oorsprongen. Bijvoorbeeld, een webapplicatie gehost op https://www.myapp.com kan API-diensten nodig hebben van https://api.serviceprovider.com of bronnen zoals afbeeldingen en scripts van verschillende domeinen ophalen. CORS stelt zulke webapplicaties in staat om toegang te krijgen tot bronnen van verschillende domeinen, terwijl de veiligheid en privacy van de gebruikersdata behouden blijven.

Begrijpen van origins in webontwikkeling

In webontwikkeling is de term "origin" (oorsprong) fundamenteel, maar vaak verkeerd begrepen. Een oorsprong wordt gedefinieerd door de combinatie van het schema (protocol), de host (domein) en de URL-poort. Bijvoorbeeld, de URL https://www.example.com:443 vertegenwoordigt een oorsprong waarbij het protocol HTTPS is, het domein www.example.com en de poort 443. Dit concept van oorsprongen is cruciaal, omdat het de ruggengraat vormt van webbeveiligingsmodellen, met name het same-origin policy.

Wat is Cross-Origin Resource Sharing?

Cross-Origin Resource Sharing is een webbrowsertechnologie die gecontroleerde toegang tot bronnen buiten een bepaalde oorsprong mogelijk maakt. In wezen is CORS een protocol waarmee webservers andere oorsprongen dan hun eigen oorsprong kunnen specificeren van waaruit een browser de bron mag laden. Dit protocol breidt HTTP uit met nieuwe headers waarmee servers kunnen beschrijven welke oorsprongen toegang mogen hebben tot die informatie via een webbrowser. Bovendien stelt het servers in staat methoden en headers te verklaren die zijn toegestaan voor cross-origin verzoeken en of credentials (cookies of authenticatiegegevens) mogen worden gedeeld tussen oorsprongen.

De aanpassing van de standaard beveiligingsbenadering

Traditioneel handhaven webbrowsers een beveiligingsmaatregel die bekend staat als de same-origin policy. Dit beleid beperkt hoe scripts of documenten van de ene oorsprong kunnen omgaan met bronnen van andere oorsprongen. Het primaire doel is om te voorkomen dat kwaadaardige scripts op één pagina toegang krijgen tot gevoelige data op een andere pagina via acties van de browser.

CORS fungeert als een gecontroleerde versoepeling van dit beleid. Door gebruik te maken van aanvullende HTTP-headers, biedt CORS een framework voor een webserver om te communiceren met en de same-origin policy van de browser te versoepelen. Bijvoorbeeld, als een webapplicatie op https://webapp.example.com bronnen nodig heeft van https://api.example.com, kan CORS veilig deze cross-origin verzoeken toestaan.

Hier zijn de belangrijkste componenten die CORS beheert:

Door deze mechanismen zorgt CORS ervoor dat de webserver expliciete autoriteit heeft over het toestaan van specifieke cross-origin verzoeken, terwijl de algehele veiligheid die door het same-origin beleid wordt bepaald, behouden blijft. Deze zorgvuldige balans helpt de integriteit en veiligheid van webapplicaties te behouden, terwijl de flexibiliteit wordt geboden die nodig is om te integreren met diverse diensten en bronnen op het web.

Het belang van Cross-Origin Resource Sharing

Het belang van Cross-Origin Resource Sharing mag niet worden onderschat. Naarmate applicaties meer worden geïntegreerd met diverse diensten en databronnen, faciliteert CORS deze interacties zonder concessies te doen aan de veiligheid. Het beleid stelt ontwikkelaars in staat om veilig en legaal verzoeken naar verschillende domeinen te sturen, terwijl ze voldoen aan strenge beveiligingsnormen en de nodige bronnen leveren voor webapplicaties om efficiënt te functioneren.

Praktische scenario’s waar CORS essentieel is

Om het praktische belang van CORS beter te begrijpen, laten we enkele veelvoorkomende scenario's verkennen waar het cruciaal is:

  1. API-gebruik: De meeste moderne webapplicaties interageren met verschillende API's die op verschillende domeinen zijn gehost. Bijvoorbeeld, een frontend applicatie op https://www.myapp.com moet mogelijk gebruikersdata ophalen van een API op https://api.userdata.com. CORS-instellingen op de API-server bepalen of deze verzoeken zijn toegestaan, zodat alleen gespecificeerde oorsprongen gevoelige informatie kunnen ophalen.

  2. Content Delivery Networks (CDN’s): Veel websites gebruiken CDN’s om statische content zoals afbeeldingen, stylesheets en scripts efficiënt te leveren. CORS is noodzakelijk wanneer bronnen worden gehost op een ander domein (bijv. https://cdn.example.com) dan de website (`https://www.example.com`), waardoor de browser content veilig over oorsprongen heen kan laden en uitvoeren.

  3. Font sharing: Webfonts worden vaak op aparte domeinen gehost zodat ze door meerdere sites kunnen worden gebruikt. CORS moet correct worden geconfigureerd op de server van de fontprovider om cross-origin fontverzoeken toe te staan, zodat browsers deze fonts over verschillende sites kunnen laden.

  4. Derde partij plugins en widgets: Websites integreren vaak externe plugins of widgets, zoals socialmediaknoppen of videospelers. Deze elementen hebben vaak toegang nodig tot bronnen die op andere domeinen zijn gehost en CORS faciliteert hun integratie op een veilige manier.

Verbeteren van applicatiefuncties zonder compromissen op veiligheid

CORS biedt een systematische aanpak van resource sharing die prioriteit geeft aan veiligheid. Door specifieke regels te definiëren over wie toegang mag krijgen tot bronnen en onder welke voorwaarden, zorgt CORS ervoor dat alleen geautoriseerde sites gevoelige of privégegevens kunnen opvragen. Dit voorkomt dat kwaadaardige sites toegang krijgen tot data die ze niet zouden moeten zien, terwijl legitieme sites volledig en effectief kunnen functioneren.

CORS gaat niet alleen over het toestaan van toegang, maar doet dit op een gecontroleerde en veilige manier. Het CORS-protocol bevat voorzieningen voor het verzenden van credentials met cross-origin verzoeken, het specificeren van welke HTTP-methoden en headers zijn toegestaan en ervoor zorgen dat preflight controles complexe verzoeken valideren voordat ze worden uitgevoerd. Deze uitgebreide aanpak helpt de integriteit en veiligheid van zowel de aanbieder van de bron als de consument te behouden.

Hoe werkt CORS?

CORS werkt door een reeks HTTP-headers die bepalen hoe browsers en servers communiceren over cross-origin verzoeken. Er zijn twee soorten CORS-verzoeken: eenvoudige verzoeken en voorgevluchte verzoeken. Het begrijpen hiervan zal verduidelijken hoe CORS het delen van bronnen over verschillende oorsprongen mogelijk maakt of beperkt.

Eenvoudige verzoeken

Een eenvoudig CORS-verzoek voldoet aan specifieke criteria die het als voldoende veilig beschouwen om geen voorvluchtcontrole te vereisen. Dit zijn meestal verzoeken die gebruikmaken van de methoden:

De enige headers die handmatig mogen worden ingesteld zijn:

Bijvoorbeeld, een GET-verzoek om een openbare bron zoals een afbeelding of een script van een CDN op te halen, wordt vaak behandeld als een eenvoudig verzoek.

Wanneer een eenvoudig verzoek wordt gedaan, voegt de browser automatisch een Origin-header toe aan het HTTP-verzoek. De server controleert deze Origin tegen zijn CORS-beleid. Als de oorsprong is toegestaan, reageert de server met de header Access-Control-Allow-Origin in de reactie. Deze header vertelt de browser of het de webpagina toegang tot de bron moet geven.

Preflighted verzoeken

Voor verzoeken die andere methoden gebruiken dan GET, POST, HEAD, of headers buiten de toegestane lijst voor eenvoudige verzoeken, stuurt de browser eerst een HTTP OPTIONS-verzoek naar de doelserver. Dit verzoek wordt een "preflight verzoek" genoemd en controleert of het daadwerkelijke verzoek veilig is om te verzenden.

Tijdens de preflight stuurt de browser headers zoals:

Deze headers informeren de server over de HTTP-methode en headers die het daadwerkelijke verzoek van plan is te gebruiken.

De server reageert dan met:

Als de server het prefelight verzoek goedkeurt, stuurt de browser het daadwerkelijke verzoek. Zo niet, dan blokkeert de browser het verzoek.

Headers betrokken bij CORS

Belangrijke HTTP-headers spelen een cruciale rol in hoe CORS wordt geïmplementeerd:

Door dit complexe systeem van verzoeken en headers biedt CORS een robuust mechanisme voor het beheren van cross-origin verzoeken op een manier die functionaliteit met veiligheid in balans houdt. Dit zorgt ervoor dat ontwikkelaars interactieve, rijk aan resources webapplicaties kunnen ontwerpen terwijl ze strikt vasthouden aan veiligheidspraktijken.

CORS implementeren

Het correct instellen van CORS is cruciaal voor de veiligheid en functionaliteit van je webapplicaties. Hier bespreken we de basisstappen en overwegingen voor het implementeren van CORS aan de serverzijde. Dit omvat verschillende omgevingen zoals Apache, Nginx en Node.js servers.

Algemene setup

  1. Identificeer Welke Oorsprongen Toegestaan Zijn: Voordat je CORS implementeert, bepaal welke oorsprongen toegang moeten hebben tot je bronnen. Dit kan een specifiek domein zijn (`https://example.com`), meerdere domeinen, of alle domeinen (`*`).

  2. Configureer CORS Headers: Configureer de juiste CORS-headers op basis van je beveiligingsvereisten en de soorten verzoeken die je server zal afhandelen. Deze headers omvatten Access-Control-Allow-Origin, Access-Control-Allow-Methods, Access-Control-Allow-Headers en mogelijk Access-Control-Allow-Credentials als je bronnen moeten worden geopend met cookies of authenticatie.

  3. Test de CORS Configuratie: Na het instellen van de headers, test de configuratie grondig met verschillende oorsprongen om ervoor te zorgen dat CORS werkt zoals verwacht en dat er geen veiligheidslekken zijn.

Specifieke serverconfiguraties

const cors = require('cors');
const app = require('express')();

// CORS inschakelen voor alle routes
app.use(cors());

// CORS inschakelen voor een specifieke route
app.get('/data', cors(), (req, res) => {
    res.json({msg: 'Deze route ondersteunt CORS'});
});

Client-side handling van CORS

Hoewel CORS primair is geconfigureerd op de server, is het begrijpen van de impact ervan op de client ook essentieel.

Testen en validatie

Zodra CORS is geïmplementeerd, is rigoureus testen noodzakelijk. Gebruik tools zoals Postman of curl om verzoeken vanuit verschillende oorsprongen te simuleren om te verifiëren dat CORS-headers correct worden toegepast en dat alleen toegestane verzoeken succesvol zijn.

Voorbeeld curl test

curl -H "Origin: http://example.com" \
     -I https://api.yoursite.com/data \
     -X GET

Deze opdracht simuleert een GET-verzoek van http://example.com naar https://api.yoursite.com/data, zodat je de headers in de respons kunt inspecteren om een correcte CORS-configuratie te verzekeren.

Door deze richtlijnen te volgen en zorgvuldig je CORS-configuratie te testen, kun je ervoor zorgen dat je webapplicaties veilig zijn en correct functioneren over verschillende domeinen. Dit beschermt je bronnen en biedt een betere gebruikerservaring door legitieme cross-domain interacties toe te staan.

Veiligheids overwegingen

Het implementeren van CORS omvat het mogelijk maken dat websites verzoeken doen naar bronnen van verschillende oorsprongen. Dit moet met zorgvuldige aandacht voor de beveiligingsimplicaties worden gedaan. Onjuist geconfigureerde CORS-beleiden kunnen applicaties blootstellen aan verschillende veiligheidsrisico's, waaronder datalekken en cross-site scripting (XSS) aanvallen.

Potentiële risico’s

Best practices voor het beveiligen van CORS configuratie

Om risico’s te beperken en applicaties te beveiligen, volg deze best practices bij het configureren van CORS:

  1. Specificeer toegestane oorsprongen: Vermijd het gebruik van de wildcard * voor gevoelige eindpunten. Specificeer exacte oorsprongen waar mogelijk, of gebruik een whitelistbenadering om Access-Control-Allow-Origin dynamisch in te stellen op basis van een vertrouwde lijst.

  2. Beperk blootgestelde headers: Stel alleen headers bloot die nodig zijn voor de clientapplicatie. Vermijd het blootstellen van gevoelige headers tenzij nodig.

  3. Valideer voorvlucht verzoeken: Configureer voorvluchtresponsen met de juiste Access-Control-Allow-Methods en Access-Control-Allow-Headers om ervoor te zorgen dat alleen legitieme cross-origin verzoeken worden toegestaan.

  4. Gebruik veilige en HttpOnly cookies: Wanneer credentials betrokken zijn, zorg ervoor dat cookies als Secure en HttpOnly zijn gemarkeerd om toegang via client-side scripts te voorkomen.

  5. Beoordeel en werk CORS-beleid regelmatig bij: Net als bij elk beveiligingsbeleid, beoordeel en werk CORS-instellingen periodiek bij om aan te passen aan nieuwe veiligheidsinzichten of wijzigingen in de architectuur van de applicatie.

Veelvoorkomende uitdagingen en oplossingen

Het configureren van CORS kan tot uitdagingen leiden, vooral in complexe applicaties die meerdere services omvatten of een hoge mate van beveiliging vereisen. Hier zijn enkele veelvoorkomende problemen en hoe je ze kunt oplossen:

Door vast te houden aan deze beveiligingsoverwegingen en best practices, kunnen ontwikkelaars ervoor zorgen dat CORS wordt geïmplementeerd om de functionaliteit van hun webapplicaties te ondersteunen, terwijl hoge beveiliging wordt gehandhaafd om zowel de data als de eindgebruikers te beschermen.

Veelvoorkomende uitdagingen en problemen oplossen

CORS, hoewel essentieel, kan een reeks uitdagingen introduceren voor ontwikkelaars, vooral voor degenen die nieuw zijn met de concepten of werken in complexe omgevingen. Hier zijn enkele van de meest voorkomende problemen die zich voordoen bij het implementeren en beheren van CORS:

  1. Onjuiste headers: Een van de meest voorkomende fouten betreft onjuiste of ontbrekende headers. Dit kan voorkomen dat CORS correct functioneert, waardoor browsers verzoeken blokkeren.

  2. Verkeerd geconfigureerde allow-origin: Fouten bij het instellen van Access-Control-Allow-Origin, zoals het verkeerd gebruik van wildcards of het specificeren van de verkeerde domeinen, kunnen legitieme toegang beperken of bronnen blootstellen aan ongeautoriseerde oorsprongen.

  3. Complexiteit van voorvluchtverzoeken: Misverstanden of verkeerde configuratie van voorvluchtverzoeken kunnen tot mislukking leiden, zelfs als het verzoek correct is opgemaakt en veilig is.

  4. Afhandelen van credentials: Onjuiste afhandeling van Access-Control-Allow-Credentials en gerelateerde headers kan leiden tot beveiligingslekken of functionele problemen, vooral wanneer credentials nodig zijn voor het verzoek.

  5. Dynamische oorsprongvalidatie: Het veilig implementeren van dynamische oorsprongvalidatie kan uitdagend zijn, vooral in omgevingen met veel potentiële geldige oorsprongen.

Problemen met CORS oplossen

Effectief oplossen van problemen is cruciaal voor het snel oplossen van CORS-problemen. Hieronder staan strategieën om veelvoorkomende CORS-gerelateerde problemen te diagnosticeren en op te lossen:

Controleer serverresponsheaders

Gebruik ontwikkeltools van de browser of commandoregeltools zoals curl om de headers te inspecteren die van de server worden ontvangen. Dit kan helpen verifiëren dat CORS-headers aanwezig en correct geconfigureerd zijn. Een voorbeeld van een curl-opdracht kan er als volgt uitzien:

curl -I -H "Origin: http://example.com" https://api.yoursite.com/resource

Deze opdracht haalt headers op voor een CORS-verzoek en laat je zien of Access-Control-Allow-Origin en andere noodzakelijke CORS-headers correct zijn ingesteld.

Controleer serverconfiguratie

Zorg ervoor dat de CORS-configuratie van je server correct is. Dit omvat het controleren van configuraties in webserversoftware (zoals Apache of Nginx) of applicatiecode (zoals Node.js of Spring). Verifieer dat de instellingen overeenkomen met je CORS-beleid, vooral met betrekking tot toegestane oorsprongen, methoden en headers.

Test met verschillende clients

Als problemen aanhouden, probeer verzoeken te doen vanaf verschillende clients of tools om te bepalen of het probleem bij een specifieke browser ligt of een bredere configuratiekwestie is.

Schakel gedetailleerde logboekregistratie in

Als je server het ondersteunt, schakel dan gedetailleerde logboekregistratie in om de stroom van CORS-verzoeken en -responsen vast te leggen. Dit kan inzicht bieden in waar het proces mogelijk misloopt.

Gebruik CORS testtools

Er zijn verschillende online tools en software librarires beschikbaar om CORS-instellingen te testen en debuggen. Tools zoals Postman kunnen verzoeken van verschillende oorsprongen simuleren en serverresponsen weergeven.

Veelvoorkomende oplossingen

Hier zijn enkele snelle oplossingen voor veelvoorkomende CORS-problemen:

Door deze troubleshooting stappen en oplossingen te volgen, kunnen ontwikkelaars CORS-problemen effectiever beheren, wat leidt tot soepelere ontwikkelervaringen en meer veilige, functionele webapplicaties.

Expertbegeleiding

Het begrijpen en implementeren van Cross-Origin Resource Sharing is essentieel voor moderne webontwikkeling. Het zorgt ervoor dat je applicaties veilig kunnen communiceren met bronnen over verschillende oorsprongen, wat de functionaliteit verbetert zonder concessies te doen aan de veiligheid. We hebben CORS verkend, waarom het belangrijk is, hoe het werkt en de best practices voor de implementatie en beveiliging ervan.

Of je nu complexe applicaties bouwt die bronnen nodig hebben van meerdere oorsprongen of API's beheert die diverse clients bedienen, CORS is een tool die je moet overwegen. Het maakt resource sharing mogelijk en behoudt de integriteit van het beveiligingsmodel van het web.

Als je vragen hebt over CORS, hulp nodig hebt bij het oplossen van problemen met je CORS-configuratie, of ervoor wilt zorgen dat je implementatie zo veilig en effectief mogelijk is, aarzel dan niet om contact met ons op te nemen. Ons team staat klaar om deskundig advies en ondersteuning te bieden om ervoor te zorgen dat je CORS-configuratie foutloos is en je webapplicaties robuust en veilig zijn. Neem contact met ons op om je webontwikkelingsstrategie te verbeteren en applicaties te beschermen tegen veelvoorkomende internetkwetsbaarheden. Samen kunnen we een veiliger en beter verbonden web bouwen.

Veelgestelde vragen
Waar wordt CORS voor gebruikt?

Cross-Origin Resource Sharing (CORS) stelt webapplicaties in staat om verzoeken te doen naar domeinen anders dan hun eigen, waardoor resource sharing over verschillende oorsprongen mogelijk wordt. Het is essentieel voor het veilig toegankelijk maken van bronnen zoals API's, lettertypen en content die op externe servers worden gehost, wat de functionaliteit en gebruikerservaring verbetert zonder concessies te doen aan de veiligheid.


Wat is CORS in web API?

In de context van web API's is CORS een mechanisme dat scripts die draaien op een browserclient in staat stelt om te communiceren met bronnen van een andere oorsprong. Dit is cruciaal voor moderne webapplicaties die afhankelijk zijn van verschillende externe API's voor data en functionaliteit, en zorgt ervoor dat de server API-verzoeken toestaat van de clientzijde onder gecontroleerde omstandigheden.


Wat is CORS en hoe los je het op?

CORS, of Cross-Origin Resource Sharing, is een protocol dat HTTP-headers gebruikt om een browser te vertellen dat webapplicaties die op een oorsprong draaien, toestemming hebben om geselecteerde bronnen van een andere oorsprong te benaderen. Om CORS-problemen op te lossen, zorg ervoor dat de server de juiste CORS-headers specificeert en implementeert, zoals `Access-Control-Allow-Origin`, en dat deze headers voldoen aan de vereisten van de webapplicatie die de verzoeken doet. Debuggen houdt meestal in dat deze instellingen op de server worden aangepast om overeen te komen met beveiligingsbeleid en applicatiebehoeften.


Is CORS een beveiligingsrisico?

Als het correct wordt geïmplementeerd, is CORS geen beveiligingsrisico; het is ontworpen om de veiligheid te verbeteren door flexibeler cross-origin verzoeken toe te staan terwijl het strikte controle over hen behoudt. Echter, misconfiguraties zoals het instellen van te permissieve oorsprongen of het blootstellen van gevoelige informatie via headers kunnen beveiligingsrisico's introduceren. Juiste implementatie en regelmatige herzieningen van CORS-beleid zijn essentieel om potentiële kwetsbaarheden te minimaliseren.


sefa-senturk
Sefa Şentürk
Software Engineering Consultant

Als een software engineering consultant die zich richt op de backend, ben ik toegewijd aan het bouwen van robuuste, efficiënte en schaalbare systemen die uitzonderlijke gebruikerservaringen mogelijk maken. Ik ben trots op het creëren van degelijke backend architecturen, het zorgen voor naadloze integraties en het optimaliseren van prestaties om te voldoen aan de hoogste normen van betrouwbaarheid, functionaliteit en schaalbaarheid.

Ook interessant

Nieuwsgierig geworden?

Wij vertellen je graag meer!

Contact opnemen
Tuple Logo
Veenendaal (HQ)
De Smalle Zijde 3-05, 3903 LL Veenendaal
info@tuple.nl‭+31 318 24 01 64‬
Snel navigeren
Succesverhalen