Get expert guidance in a few days with a Laravel code review

Php Cors

fruitcake/php-cors image

Php Cors stats

Downloads
48.5M
Stars
161
Open Issues
3
Forks
10

View on GitHub →

Cross-origin resource sharing library for the Symfony HttpFoundation

CORS for PHP by Fruitcake

The fruitcake/php-cors package provides a robust solution for enabling Cross-Origin Resource Sharing (CORS) in applications using PHP's Symfony HttpFoundation. This library is essential for developers needing to manage CORS policies efficiently to allow or restrict resources shared between different origins.

Key Features

  • Flexible CORS Rules: Define which HTTP methods, headers, and origins are allowed.
  • Pattern Matching: Utilize regular expressions to define allowed origins.
  • Support for Credentials: Control whether to expose credentials.
  • Configurable Response Headers: Set headers for exposed headers and maximum cache age.
  • High Compatibility: Works seamlessly as middleware for StackPHP and can be integrated into Laravel through an additional package.

Installation

Install the package via Composer:

composer require fruitcake/php-cors

Usage

Basic Configuration

You can easily integrate CORS handling within your application by configuring the following options:

  • allowedMethods: Specify which HTTP methods are permitted.
  • allowedOrigins: Define which origins can access the resources.
  • allowedHeaders: Set specific headers that can be used during the request.
  • exposedHeaders: Decide which headers are exposed in the response.
  • maxAge: Determine the time for which the response is considered valid.
  • supportsCredentials: Enable or disable cookies and authentication data.

Practical Example

Here’s how you can set up the CORS service in your PHP application:

use Fruitcake\Cors\CorsService;
 
$cors = new CorsService([
'allowedHeaders' => ['x-allowed-header', 'x-other-allowed-header'],
'allowedMethods' => ['DELETE', 'GET', 'POST', 'PUT'],
'allowedOrigins' => ['http://localhost', 'https://*.example.com'],
'exposedHeaders' => ['Content-Encoding'],
'maxAge' => 0,
'supportsCredentials' => false,
]);
 
$response = new Response();
$cors->addActualRequestHeaders($response, $origin);

Advanced Handling

The package also provides methods to handle preflight requests and check if a request is allowed under the defined CORS policy.

License

This package is released under the MIT License.

For developers looking to implement CORS in their PHP applications effectively, fruitcake/php-cors offers a powerful, flexible solution that is easy to integrate and configure. Whether you are developing a simple site or a complex RESTful service, this package is designed to meet your CORS requirements.

fruitcake photo

Your #1 dev team


Fruitcake Php Cors Related Articles

The Artisan Files: Barry vd. Heuvel image

The Artisan Files: Barry vd. Heuvel

Read article
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Harpoon: Next generation time tracking and invoicing logo

Harpoon: Next generation time tracking and invoicing

The next generation time-tracking and billing software that helps your agency plan and forecast a profitable future.

Harpoon: Next generation time tracking and invoicing
Typesense Search logo

Typesense Search

Typesense is an open source, blazing-fast search engine, optimized for helping you build delightful search experiences for your sites and apps. Natively integrated with Laravel Scout.

Typesense Search
The Certification of Competence for Laravel logo

The Certification of Competence for Laravel

A community-driven, proctored assessment across 4 levels designed to validate real-world Laravel knowledge, from Junior to mastery-level Artisan. Official Vue.js, Official Nuxt, Angular, React, JS certifications also available.

The Certification of Competence for Laravel
Laravel Cloud logo

Laravel Cloud

Easily create and manage your servers and deploy your Laravel applications in seconds.

Laravel Cloud
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell