编程语言
首页 > 编程语言> > Ajax重置PHP会话

Ajax重置PHP会话

作者:互联网

我知道this question has been asked before,所以我提前致歉,但是我已经多次超过了他的解决方案,在我看来,这不能解决会话重置问题.

我有一个简单的php页面,它输出用于调试的会话ID.像这样:

<?php
session_start();
echo session_id();
?>

然后,我有一个带有jQuery的简单HTML页面,该页面在该页面上执行ajax请求并记录输出.

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    <script>
      $.post('http://localhost.api.mydomain/sid', {
        some: 'data'
      }, function(data,status) {
        console.log(data);
      });
    </script>
  </head>
  <body>
    Check your console.
  </body>
</html>

如果我手动访问URL http://localhost.api.mydomain/sid,则输出不会更改,session_id()会保持不变,正如预期的那样.但是,如果刷新ajax页面,则每次刷新输出的session_id()都会更改.

我试过在php.ini文件中设置session.cookie_domain,但无济于事.对于这个问题,我深表歉意,但我根本找不到解决方法.

解决方法:

这是一个访问控制问题,而不是ajax问题.

当您直接从浏览器访问URL时,您正在从所访问的域中请求一个(会话)cookie.在这种情况下,使用ajax时,您是从不是您要访问的域的域请求cookie.

在api.example.com上的php API文件上,尝试执行此操作.

header('Access-Control-Allow-Origin: example.com');
header('Access-Control-Allow-Credentials: true');

然后在ajax请求文件上,像这样使用xhrFields参数.

  $.ajax({
    url: 'https://api.example.com',
    xhrFields: { withCredentials: true },
    success: function(data) {
      console.log(data)
    }
  });

现在,只要您从来源example.com调用请求,Cookie就会像预期的那样运行.

标签:ajax,session-variables,session-cookies,session,php
来源: https://codeday.me/bug/20191109/2012048.html