Skip to content

Instantly share code, notes, and snippets.

@cvega93
Last active February 20, 2019 19:05
Show Gist options
  • Save cvega93/1ed2ce526ae448e1bd919b50a48587be to your computer and use it in GitHub Desktop.
Save cvega93/1ed2ce526ae448e1bd919b50a48587be to your computer and use it in GitHub Desktop.
Headers for crossdomain requests in PHP + Options validation. [Solve CORS error]
<?php
if (isset($_SERVER['HTTP_ORIGIN'])) {
// Decide if the origin in $_SERVER['HTTP_ORIGIN'] is one
// you want to allow, and if so:
header("Access-Control-Allow-Origin: {$_SERVER['HTTP_ORIGIN']}");
header('Access-Control-Allow-Credentials: true');
header('Access-Control-Max-Age: 86400'); // cache for 1 day
}
// Access-Control headers are received during OPTIONS requests
if ($_SERVER['REQUEST_METHOD'] == 'OPTIONS') {
if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD']))
// may also be using PUT, PATCH, HEAD etc
header("Access-Control-Allow-Methods: GET, POST, OPTIONS");
if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']))
header("Access-Control-Allow-Headers: {$_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']}");
exit(0);
}
header('Access-Control-Allow-Origin: *');
header('Content-Type: application/json');
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment