Support the ongoing development of Laravel.io →
Authentication

Pardon my newbie-ness, but I'm new to Laravel and developing RESTFUL APIs in general. I found documentation that showed me how to accept CORS requests from a different domain. First, what I found seems a bit restrictive. See sample below:

App::before(function($request) { if($_SERVER['REQUEST_METHOD'] === 'OPTIONS') { $statusCode = 204; $headers = [ 'Access-Control-Allow-Origin' => 'http://mydummydomain', 'Access-Control-Allow-Methods' => 'GET, POST, OPTIONS', 'Access-Control-Allow-Headers' => 'Origin, Content-Type, Accept, Authorization, X-Requested-With', 'Access-Control-Allow-Credentials' => 'true' ]; return Response::make(null, $statusCode, $headers); } });

Is there some way of making this more generic, i.e. accept CORS request from any domain? Can I specify Access-Control-Allow-Origin' => '*'? If not, (and this is also quite newbie) what sort of domain is sent with mobile apps? localhost? or is it dependent on vendor? Thanks in advance

Last updated 2 years ago.
0

Yes you can specify * for the origin. Otherwise you would need to know the origin of each device / network before they tried to connect.

Last updated 2 years ago.
0

You can also try https://github.com/barryvdh/laravel-cors

  • works, but not with basic auth. You can however also just return the requested host. ( $_SERVER['HTTP_ORIGIN'] or $request->headers->get('Origin') )
Last updated 2 years ago.
0

Go with barry's package because it worked wonders for me, you can also do the dirty and set your headers with PHP header in the route but I don't recommend that. Create your own auth.customname filter to do what you need to do for CORS like hashsalting, like Barryvdh said it's not going to work because it stores your session under that domain only.

Last updated 2 years ago.
0

Here's a package you can salt with, I'm kinda doing my own thing called auth.fb it's custom to auth with facebook.

http://docs.toddish.co.uk/verify-l4/

Last updated 2 years ago.
0

barryvdh said:

You can also try https://github.com/barryvdh/laravel-cors

  • works, but not with basic auth. You can however also just return the requested host. ( $_SERVER['HTTP_ORIGIN'] or $request->headers->get('Origin') )

Rock on barry, I like your solution much better and it works will with 4.1 I also found it handy because of the flexibility you added to specifically change headers based on exact paths or catch all.

Last updated 2 years ago.
0

Sign in to participate in this thread!

Eventy

Your banner here too?

johnlamont johnlamont Joined 19 Feb 2014

Moderators

We'd like to thank these amazing companies for supporting us

Your logo here?

Laravel.io

The Laravel portal for problem solving, knowledge sharing and community building.

© 2025 Laravel.io - All rights reserved.