首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当请求的凭据模式为“包括”时,响应中的“访问-控制-允许-原产地”头不能是通配符“*”。

当请求的凭据模式为“包括”时,响应中的“访问-控制-允许-原产地”头不能是通配符“*”。
EN

Stack Overflow用户
提问于 2018-07-08 11:50:08
回答 2查看 19.2K关注 0票数 1

我正在尝试将我的电子应用程序转换成完整的网页。当我从本地主机运行应用程序时,我会得到以下错误:

加载https://agrt.herokuapp.com/login失败:对飞行前请求的响应没有通过访问控制检查:当请求的凭据模式为“包括”时,响应中的“访问控制-允许-原产地”标题的值不能是通配符“*”。因此,“http://localhost:4200”源是不允许访问的。由XMLHttpRequest发起的请求的凭据模式由withCredentials属性控制。

在我的客户端,我发送了一个http请求:

代码语言:javascript
复制
this.http.post(Consts.REMOTE_URL + '/login', {
      username: username,
      password: password
    }, {withCredentials:true}).

在我的服务器上,我使用我设置的cors:

代码语言:javascript
复制
app.use(function(req,res,next){
        res.header("Access-Control-Allow-Origin","http://localhost:4200");
        res.header('Access-Control-Allow-Headers', 'X-Requested-With,content-type, Accept');
        res.header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
        res.header('Access-Control-Allow-Credentials', true);
        next();
    })

我的服务器在heroku.

当我从电子中运行时,一切都进行得很好。

拜托,任何帮助都会很棒的!

server.js:

代码语言:javascript
复制
const express = require('express')
const passport = require('passport')
const winston = require('winston')
const db = require('./db')
const cors = require('cors')
require('dotenv').config()

const port = process.env.PORT || 9000
const app = express()

app.use(cors())
require('./config/passport')(passport, db)
require('./config/express')(app, passport, db.pool, db)
require('./app/routes')(app, passport)

app.use(function (err, req, res, next) {
  if (err.message && (~err.message.indexOf('not found'))) {
    return next()
  }
  winston.error(err.stack)
  return res.status(500).json({error: 'Error on backend occurred.'})
})

const server = app.listen(port, () => {
  console.log("listening to port: "+port);
  if(app.get('env') === 'test') return

  winston.log('Express app started on port ' + port)
})

server.on('close', () => {
  winston.log('Closed express server')

  db.pool.end(() => {
    winston.log('Shut down connection pool')
  })
})

express.js:

代码语言:javascript
复制
const path = require('path')
const express = require('express')
const expressHandlebars = require('express-handlebars')
const expressValidator = require('express-validator')
const session = require('express-session')
const pgSession = require('connect-pg-simple')(session)
const bodyParser = require('body-parser')
const cookieParser = require('cookie-parser')
const methodOverride = require('method-override')
const morgan = require('morgan')
const winston = require('winston')
const config = require('./')
const resumable = require('../app/lib/resumablejs')
const env = process.env.NODE_ENV || 'development'

module.exports = (app, passport, pool, db) => {
    let log = 'dev'
    if (env !== 'development') {
    log = {
      stream: {
        write: message => winston.info(message)
      }
    }
  }

    if (env !== 'test') app.use(morgan(log))

    app.engine('handlebars', expressHandlebars())
    app.set('view engine', 'handlebars')

    app.use(bodyParser.json())
    app.use(bodyParser.urlencoded({ extended: true }))
    app.use(expressValidator())

    app.use(methodOverride(function (req) {
        if (req.body && typeof req.body === 'object' && '_method' in req.body) {
            var method = req.body._method
            delete req.body._method
            return method
        }
    }))

    app.use(cookieParser())
    app.use(session({
        store: new pgSession({
            pool
        }),
        secret: config.session_secret,
        // saveUninitialized: false,
        // resave: false,
         cookie: { maxAge: 14 * 24 * 60 * 60 * 1000 }
    }))

    /////////////////////////////////////////
    app.use(function(req,res,next){
        res.header("Access-Control-Allow-Origin","http://localhost:4200");
        res.header('Access-Control-Allow-Headers', 'X-Requested-With,content-type, Accept');
        res.header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
        res.header('Access-Control-Allow-Credentials', true);
        next();
    })
    //////////////////////////////////////////

    app.use(passport.initialize())
    app.use(passport.session())

    app.use('/', express.static(path.join(config.root, 'public')))
    app.use('/files', resumable(undefined, undefined, db))
}
EN

回答 2

Stack Overflow用户

发布于 2018-09-06 19:14:44

尝试使用以下配置:

代码语言:javascript
复制
app.use(function(req, res, next) {
  res.header("Access-Control-Allow-Credentials", true);
  res.header("Access-Control-Allow-Origin", req.headers.origin);
  res.header("Access-Control-Allow-Methods", "GET,PUT,POST,DELETE");
  res.header(
    "Access-Control-Allow-Headers",
    "X-Requested-With, X-HTTP-Method-Override, Content-Type, Accept"
  );
  if ("OPTIONS" == req.method) {
    res.send(200);
  } else {
    next();
  }
});
票数 0
EN

Stack Overflow用户

发布于 2022-01-12 07:31:01

或者,如果您正在使用CORS中间件,并且希望发送withCredentials布尔值true (例如,发送带有set-cookie头的响应),则可以像这样配置CORS:

代码语言:javascript
复制
const corsOptions = {
  origin: ["http://localhost:3000"],
 //update: or "origin: true," if you don't wanna add a specific one
  credentials: true,
};
app.use(cors(corsOptions));
  • 为了使用凭据app.use(corse())不能工作,您应该在corsOptions中指定您的特定来源。

它(在某种程度上)等于设置这样的响应头:

代码语言:javascript
复制
app.all("*", function (req, res, next) {
  res.header("Access-Control-Allow-Origin", "http://localhost:3000");
  res.header("Access-Control-Allow-Credentials", true);
  res.header("Access-Control-Allow-Methods", "PUT, GET, POST, DELETE, OPTIONS");
  res.header("Access-Control-Allow-Headers", "Content-Type");
  next();
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51231699

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档