To get started, you will first need to create the appropriate request object. Nicholas Zakas wrote [a simple helper method](http://www.nczonline.net/blog/2010/05/25/cross-domain-ajax-with-cross-origin-resource-sharing/) to help sort out the browser differences:
To get started, you will first need to create the appropriate request object. Nicholas Zakas wrote [a simple helper method](http://www.nczonline.net/blog/2010/05/25/cross-domain-ajax-with-cross-origin-resource-sharing/) to help sort out the browser differences:
```
```javascript
function createCORSRequest(method, url) {
function createCORSRequest(method, url) {
var xhr = new XMLHttpRequest();
var xhr = new XMLHttpRequest();
if ("withCredentials" in xhr) {
if ("withCredentials" in xhr) {
...
@@ -85,7 +85,7 @@
...
@@ -85,7 +85,7 @@
For most cases, you will at the very least want to handle the `onload` and `onerror` events:
For most cases, you will at the very least want to handle the `onload` and `onerror` events:
```
```javascript
xhr.onload = function() {
xhr.onload = function() {
var responseText = xhr.responseText;
var responseText = xhr.responseText;
console.log(responseText);
console.log(responseText);
...
@@ -103,13 +103,13 @@
...
@@ -103,13 +103,13 @@
Standard CORS requests do not send or set any cookies by default. In order to include cookies as part of the request, you need to set the XMLHttpRequest’s `.withCredentials` property to true:
Standard CORS requests do not send or set any cookies by default. In order to include cookies as part of the request, you need to set the XMLHttpRequest’s `.withCredentials` property to true:
```
```javascript
xhr.withCredentials = true;
xhr.withCredentials = true;
```
```
In order for this to work, the server must also enable credentials by setting the Access-Control-Allow-Credentials response header to “true”. See the [server section](https://www.html5rocks.com/en/tutorials/cors/#toc-adding-cors-support-to-the-server) for details.
In order for this to work, the server must also enable credentials by setting the Access-Control-Allow-Credentials response header to “true”. See the [server section](https://www.html5rocks.com/en/tutorials/cors/#toc-adding-cors-support-to-the-server) for details.
```
```http
Access-Control-Allow-Credentials: true
Access-Control-Allow-Credentials: true
```
```
...
@@ -119,7 +119,7 @@
...
@@ -119,7 +119,7 @@
Now that your CORS request is configured, you are ready to make the request. This is done by calling the `send()` method:
Now that your CORS request is configured, you are ready to make the request. This is done by calling the `send()` method:
// ERROR - No CORS headers, this is an invalid request!
// ERROR - No CORS headers, this is an invalid request!
Content-Type: text/html; charset=utf-8
Content-Type: text/html; charset=utf-8
```
```
If there is an error in the CORS request, the browser will fire the client's `onerror` event handler. It will also print the following error to the console log:
If there is an error in the CORS request, the browser will fire the client's `onerror` event handler. It will also print the following error to the console log:
```
```http
XMLHttpRequest cannot load http://api.alice.com. Origin http://api.bob.com is not allowed by Access-Control-Allow-Origin.
XMLHttpRequest cannot load http://api.alice.com. Origin http://api.bob.com is not allowed by Access-Control-Allow-Origin.
```
```
...
@@ -431,7 +431,7 @@
...
@@ -431,7 +431,7 @@
Here's sample code for making a CORS request with JQuery. The comments give more details on how certain properties interact with CORS.
Here's sample code for making a CORS request with JQuery. The comments give more details on how certain properties interact with CORS.
```
```javascript
$.ajax({
$.ajax({
// The 'type' property sets the HTTP method.
// The 'type' property sets the HTTP method.
...
@@ -483,7 +483,7 @@
...
@@ -483,7 +483,7 @@
1. Include domain in manifest.json - Chrome extensions can make cross-domain requests to any domain *if* the domain is included in the "permissions" section of the manifest.json file:
1. Include domain in manifest.json - Chrome extensions can make cross-domain requests to any domain *if* the domain is included in the "permissions" section of the manifest.json file: