AJAX跨域请求无法获取cookie和传输cookie的解决办法

本文介绍了一种在跨域请求中使用Cookie的方法。通过设置前端AJAX的xhrFields属性和后端响应头来实现跨域请求携带Cookie,确保了跨域场景下数据交互的安全性和有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在做一个跨域请求的功能时需要用到cookie,但是正常的跨域浏览器不允许跨域请求带上cookie和获取cookie的,所以需要在代码上做一些修改。

前端AJAX:

$.ajax({

  type: "POST",

  url: "getlistener.php",

  dataType: 'json',

   xhrFields: {withCredentials: true},//设置withCredentials为TRUE,为TRUE而执行跨域名请求

    data:{business_id:1},

    success:function(data){

     },

    error:function(){}

});

后端执行方法:

    function getlistener(){

        $domian = $_SERVER['HTTP_ORIGIN'];//获取请求的域名

        header('Access-Control-Allow-Origin:'.$domian); //允许的域名,可以设置指定域名

        header('Access-Control-Allow-Credentials:true');//是否允许请求带有验证信息

        //处理逻辑写在这里

        return json_encode($data);

    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值