当前位置: 首页 > 知识库问答 >
问题:

在浏览器控制台中。.响应中'Access-Control-Allow-Credentials'标头的值为'',该值必须为'true'

程俊誉
2023-03-14

CORS策略阻止了从来源“http://localhost:3000/socket.io/?eio=3&transport=polling&t=nqb0bxp”访问来自“http://localhost:8100”的XMLHttpRequest:响应中的“access-control-allog-credentials”标头的值为“,当请求的凭据模式为”include“时,该标头必须为”true“。由XMLHttpRequest发起的请求的凭据模式由withCredentials属性控制。

在节点js(后端)

var express = require('express');
var app = express();
const cors = require('cors');
app.use(cors());
var bodyParser = require('body-parser')
app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json())

 

  
var server = require('http').createServer(app);
const io = require("socket.io")(server, {
cors: {
    origin: "http://localhost:8100",
    methods: ["GET", "POST"],
}
});


io.on('connection',function(socket){
    console.log("A user connected");

    // socket.emit('test event','my connection');

    socket.on('test event',(data)=>{
        console.log(data);
        socket.emit('test event','my connection');
    })

})

 
// console.log(app)
server.listen(3000,()=>{
    console.log("socket io server is listening on port 3000");
});
 import { Injectable } from '@angular/core';
import  * as io   from 'socket.io-client';
import { Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class WebSocketService {
  socket:any;
  readonly url = "ws://localhost:3000";



  constructor() {
    console.log(io,"io")
    this.socket = io.connect(this.url,{});
   }


  listen(eventName:string){
    return new Observable((subscriber)=>{
      this.socket.on(eventName , (data)=>{
        subscriber.next(data);
      });
    })
  }

  emit(eventName:string,data:any){
      this.socket.emit(eventName,data);
  }


}

共有1个答案

祝昊东
2023-03-14

io(3.x)迁移文档非常有用。

const io = require("socket.io")(httpServer, {
  cors: {
    origin: "https://example.com",
    methods: ["GET", "POST"],
    allowedHeaders: ["my-custom-header"],
    credentials: true
  }
});
 类似资料:
  • 问题内容: 我正在使用节点,在客户端上在后端和angular4上表达,这给了我以下错误: XMLHttpRequest无法加载http:// localhost:4876 / login / check 。对预检请求的响应未通过访问控制检查:响应中的“ Access- Control-Allow-Credentials”标头的值为“”,当请求的凭据模式为“ include”时,该值必须为“ tru

  • 我在后端使用node、express,在客户端使用angular4,这给了我以下错误: XMLHttpRequest无法加载http://localhost:4876/login/check。对预飞行请求的响应未通过访问控制检查:响应中“access-control-allow-credentials”标头的值为“”,当请求的凭据模式为“include”时,该值必须为“true”。因此,不允许访问

  • 我得到这些错误在浏览器 “响应必须包含AMP Access Control Allow Source Origin标头” 和 表单提交失败:错误:响应必须包含AMP Access Control Allow Source Origin标头​​​" php HTML 我如何编辑它,以避免这些错误?

  • Access-Control-Allow-Credentials响应报头指示的请求的响应是否可以暴露于该页面。当true值返回时它可以被暴露。 凭证是 Cookie ,授权标头或 TLS 客户端证书。 当作为对预检请求的响应的一部分使用时,它指示是否可以使用凭证进行实际请求。请注意,简单的GET请求不是预检的,所以如果请求使用凭证的资源,如果此资源不与资源一起返回,浏览器将忽略该响应,并且不会返回

  • 编辑: 我更改了表单以提交一个名为amp-form-submit.php的新文件 该文件看起来像: 现在我的错误是解析响应JSON:SyntaxError:JSON失败。解析:JSON数据第1行第1列的数据意外结束 我不明白我做错了什么。下面是我测试amp表单的代码。我包括AMP访问控制允许原点标题。 这是表单提交失败时的控制台: 出于隐私考虑,我已将URL替换为通用URL。此表单处理脚本与doc