共计 2179 个字符,预计需要花费 6 分钟才能阅读完成。
下载 cors
npm install cors
要害代码
const cors = require('cors');
app.use(cors());
app.all('*', function (req, res, next) {
// 域名白名单, 不能写 * , 因为 * 是通配符 所有网站都能够拜访
// res.setHeader('Access-Control-Allow-Origin', '*');
// 独自配置白名单, 也就是能进行跨域拜访的网址
res.setHeader('Access-Control-Allow-Origin', ['http://127.0.0.1:8000']);
//...Headers 必须的固定值,"content-type"
res.setHeader('Access-Control-Allow-Headers', 'X-request-With,content-type');
// res.setHeader("Access-Control-Allow-Headers","X-request-With");
res.setHeader('Access-Control-Allow-Methods', 'GET,POST,DELETE,PUT,OPTIONS');
// 放行 / 下一步 不能省
next();});
残缺代码
const express = require('express');
const path = require('path');
const logger = require('morgan');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const cookieSession = require('cookie-session');
const apiRoutes = require('./routes/api');
const cors = require('cors');
const app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
// uncomment after placing your favicon in /public
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false}));
app.use(cookieParser());
app.use(
cookieSession({
name: 'session',
secret: 'sdfasd@d34sdf@',
maxAge: 24 * 60 * 60 * 1000 * 7,
})
);
app.use(cors());
app.use(express.static(path.join(__dirname, 'public')));
// 相当于拼接门路
app.use('/api', apiRoutes);
// catch 404 and forward to error handler
app.use(function (req, res, next) {const err = new Error('Not Found');
err.status = 404;
next(err);
});
app.all('*', function (req, res, next) {
// 相当于域名白名单, 不能写 * , 因为 * 是通配符 所有网站都能够拜访
// res.setHeader('Access-Control-Allow-Origin', '*');
// 独自配置白名单, 也就是能进行跨域拜访的网址
res.setHeader('Access-Control-Allow-Origin', ['http://127.0.0.1:8000']);
//...Headers 必须的固定值,"content-type"
res.setHeader('Access-Control-Allow-Headers', 'X-request-With,content-type');
// res.setHeader("Access-Control-Allow-Headers","X-request-With");
res.setHeader('Access-Control-Allow-Methods', 'GET,POST,DELETE,PUT,OPTIONS');
// 放行 / 下一步 不能省
next();});
// error handler
app.use(function (err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
正文完