Node.js 환경에서 도메인 간 요청을 할 때 요청이 정상적으로 진행되도록 하려면 특정 구성이 필요합니다. 그렇다면 교차 도메인 구성은 정확히 어디에서 수행됩니까?
먼저 도메인 간 요청이 무엇인지 이해해야 합니다. 교차 출처 요청은 현재 페이지의 소스와 다른 URL에 액세스할 때 클라이언트가 시작한 요청을 나타냅니다. 브라우저의 동일 출처 정책 제한으로 인해 이러한 요청은 전송이 금지됩니다. Node.js는 웹 서버로 실행될 수 있으므로 특별한 요구 사항을 충족하려면 도메인 간 구성도 필요합니다.
Node.js에서 도메인 간 구성을 수행하는 방법에는 일반적으로 서버 측 구성과 클라이언트 측 구성의 두 가지 방법이 있습니다.
Node.js에서는 cors
모듈을 사용하여 도메인 간 요청을 구성할 수 있습니다. cors
모듈을 사용하기 전에 먼저 설치해야 합니다: cors
模块来进行跨域请求的配置。使用 cors
模块前,需要先进行安装:
npm install cors
安装完成后,在具体使用时,只需要引入模块即可:
const express = require('express'); const cors = require('cors'); const app = express(); app.use(cors()); // ...
其中,app.use(cors())
表示允许所有的域进行访问。如果需要对特定域进行访问授权,可以使用以下方式:
const express = require('express'); const cors = require('cors'); const app = express(); const corsOptions = { origin: 'http://example.com' } app.use(cors(corsOptions)); // ...
示例中,corsOptions
中指定了允许 http://example.com
地址进行跨域请求。
如果需要在客户端页面中发起跨域请求,也可以使用 cors
模块来进行配置。在客户端使用 cors
模块时,需要先进行安装:
npm install cors
安装完成后,在具体使用时,可以在客户端代码中进行如下配置:
const axios = require('axios'); const cors = require('cors'); const corsOptions = { origin: 'http://example.com' }; axios.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8'; axios.defaults.headers.post['Access-Control-Allow-Origin'] = '*'; axios.defaults.headers.post['Access-Control-Allow-Headers'] = 'Content-Type,Content-Length, Authorization, Accept,X-Requested-With'; axios.defaults.headers.post['Access-Control-Allow-Methods'] = 'PUT,POST,GET,DELETE,OPTIONS'; const instance = axios.create({ baseURL: 'http://localhost:3000', timeout: 1000, }); instance.defaults.headers.post['Access-Control-Allow-Origin'] = '*'; instance.defaults.withCredentials = true; instance.defaults.transformRequest = [function(data) { data = JSON.stringify(data); return data; }]; instance.defaults.transformResponse = [function(data) { if (typeof data === 'string' && data.includes('{') && data.includes('}')) { data = JSON.parse(data); } return data; }]; instance.interceptors.request.use(function(config) { config.withCredentials = true; return config; }, function(error) { return Promise.reject(error); }); instance.interceptors.response.use(function(response) { return response; }, function(error) { return Promise.reject(error); }); instance.use(cors(corsOptions)); // ...
其中,instance.use(cors(corsOptions))
表示允许 http://example.com
rrreee
rrreee
그중 app.use(cors( ))
는 모든 도메인의 액세스를 허용한다는 의미입니다. 특정 도메인에 대한 액세스를 승인해야 하는 경우 다음 방법을 사용할 수 있습니다. 🎜rrreee🎜예제에서 corsOptions
는 http://example.com
을 지정합니다. 주소는 도메인 간 질문이 허용됩니다. 🎜cors
모듈을 사용할 수도 있습니다. 클라이언트에서 cors
모듈을 사용하는 경우 먼저 설치해야 합니다. 🎜rrreee🎜설치가 완료된 후 사용 시 클라이언트 코드에서 다음을 구성할 수 있습니다. 🎜rrreee🎜 그 중 , 인스턴스.use(cors(corsOptions))
는 http://example.com
주소가 도메인 간 요청을 할 수 있음을 나타냅니다. 🎜🎜요약하자면 Node.js 환경의 도메인 간 요청은 서버 측 또는 클라이언트 측에서 구성될 수 있습니다. 실제 시나리오에 따라 도메인 간 구성을 위한 적절한 방법을 선택해야 합니다. 🎜위 내용은 nodejs 크로스 도메인을 구성하는 위치의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!