Skip to main content
Version: 3.0.0

Cross-domain

Common cross-domain components are applicable to @midwayjs/faas, @midwayjs/web, @midwayjs/koa, and @midwayjs/express frameworks, and support multiple modes of cors and jsonp.

Related information:

Web support
@midwayjs/koa
@midwayjs/faas
@midwayjs/web
@midwayjs/express

Installation dependency

$ npm i @midwayjs/cross-domain --save

Introducing components

Introducing components in src/configuration.ts.

import * as crossDomain from '@midwayjs/cross-domain';
@Configuration({
imports: [
// ...other components
crossDomain
],
})
export class MainConfiguration {}

What is Cross-Origin

Suppose there are two websites:

  • A.com: This is your website, where you want to access some resources.
  • B.com: This is another website that possesses the resources you wish to access.

Scenario Setup

  1. A.com is your main website, where you run some JavaScript code.
  2. B.com has some API interfaces that you want to call through JavaScript code on A.com.

Due to the same-origin policy, browsers do not allow JavaScript code from A.com to directly access resources from B.com by default. This is because browsers, for security reasons, prevent malicious websites from reading sensitive data from other sites. You want to initiate a request to B.com's API interface from JavaScript code running on A.com, and this request is considered a cross-origin request.

In simple terms, accessing B.com's interface from A.com is cross-origin.

Additionally, there are some conditions for cross-origin:

    1. The same-origin policy is part of the browser's security mechanism, so cross-origin issues generally only arise when accessing from a browser.
    1. When a browser initiates a cross-origin request, it automatically adds an Origin header to the request based on the current origin, and the server also judges the source based on the origin header and processes accordingly.

So, when you find that cross-origin settings are not effective, please check:

    1. Whether it is indeed a cross-origin request.
    1. Whether it is indeed initiated from a browser.
    1. Whether the request carries an origin header.

What is CORS

The following errors are often encountered when front-end code calls back-end services. This is the most common cross-domain CORS error. .

Access to fetch at 'http://127.0.0.1:7002/' from origin 'http://127.0.0.1:7001' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.

For security reasons, browsers restrict cross-origin HTTP requests made within scripts. For example, XMLHttpRequest and Fetch API follow the [Same Origin Policy](https://developer.mozilla.org/ en-CN/docs/Web/Security/Same-origin_policy). This means that web applications using these APIs can only request HTTP resources from the same domain where the application is loaded unless the response message contains the correct CORS response headers.

The CORS mechanism allows web application servers to perform cross-origin access control so that cross-origin data transmission can be carried out securely. Modern browsers support this in API containers such as XMLHttpRequest or [Fetch](https://developer.mozilla .org/zh-CN/docs/Web/API/Fetch_API)) uses CORS to reduce the risks caused by cross-origin HTTP requests.

Common CORS configurations

Below are several cross-domain solutions. Let’s take the fetch method as an example.

credentials not used

client.

fetch(url);

Server configuration.

// src/config/config.default.ts
export default {
// ...
cors: {
origin: '*',
},
}

Using credentials

client.

fetch(url, {
credentials: "include",
});

Server configuration

// src/config/config.default.ts
export default {
// ...
cors: {
credentials: true,
},
}

Limit origin

Suppose our web page address is http://127.0.0.1:7001 and the interface is http://127.0.0.1:7002.

client.

fetch('http://127.0.0.1:7002/', {
credentials: 'include'
})

Server configuration, please note that since credentials is enabled, the origin field cannot be * at this time.

// src/config/config.default.ts
export default {
// ...
cors: {
origin: 'http://127.0.0.1:7001',
credentials: true,
},
}

More CORS configuration

The available configurations are as follows:

export const cors = {
// Allow cross-domain methods, [default value] is GET, HEAD, PUT, POST, DELETE, PATCH
allowMethods: string |string[];
// Set the value of Access-Control-Allow-Origin, and [Default] will get the origin on the request header
// It can also be configured as a callback method. The input parameter is request and the origin value needs to be returned.
// For example: http://test.midwayjs.org
// If credentials is set, origin cannot be set *
origin: string|Function;
// Set the value of Access-Control-Allow-Headers, [Default] will get Access-Control-Request-Headers on the request head
allowHeaders: string |string[];
// Set the value of Access-Control-Expose-Headers
exposeHeaders: string |string[];
// Set Access-Control-Allow-Credentials, [Default] false
// It can also be configured as a callback method. The input parameter is request and the return value is true or false.
credentials: boolean|Function;
// Whether to write cross-domain header information to the headers attribute of the error pair when an error is reported, [default value] false
keepHeadersOnError: boolean;
// set Access-Control-Max-Age
maxAge: number;
}

JSONP configuration

JSONP can be configured in src/config/config.default.

// src/config/config.default.ts
export default {
// ...
jsonp: {
callback: 'jsonp',
limit: 512
},
}