Search code examples
javascripthtmlsecuritycorsdenial-of-service

Security implications of adding all domains to CORS (Access-Control-Allow-Origin: *)


It is said that instead of adding all domains to CORS, one should only add a set of domains. Yet it is sometimes not trivial to add a set of domains. E.g. if I want to publicly expose an API then for every domain that wants to make a call to that API I would need to be contacted to add that domain to the list of allowed domains.

I'd like to make a conscious trade off decision between security implications and less work.

The only security issues I see are DoS attacks and CSRF attacks. CSRF attacks can already be achieved with IMG elements and FORM elements. DoS attacks related to CORS can be overcome by blocking requests upon the referrer header.

Am I missing security implications?

  • It is assumed that the Access-Control-Allow-Credentials Header is not set
  • I know how to add a given list of domains "CORS access" and I'm therefore only interested in the security implications of adding all domains "CORS access"

Solution

  • Except of csauve's one, none of the replies answer my original question.

    To answer my question; It seems that as long as Access-Control-Allow-Credentials is not set then there is no security problem.

    (Which makes me wonder why the spec requires preflight when Access-Control-Allow-Credentials is not set?)