php - Ajax 重置 PHP session

标签 php ajax session session-variables session-cookies

我知道this question has been asked before所以我提前道歉,但我已经多次检查他的解决方案,但它并没有解决我的 session 重置问题。

我有一个简单的 php 页面,它输出用于调试的 session 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 但无济于事。对于这个问题,我深表歉意,但我实在找不到解决方案。

最佳答案

这是一个 Access-Control 问题,而不是 ajax 问题。

当您直接从浏览器访问 url 时,您是在从您正在访问的域中请求一个( session )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 就会按预期运行。

关于php - Ajax 重置 PHP session ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49514987/

相关文章:

javascript - 将 PHP 数组值插入 JavaScript 数组?

Java - PHP 的 URLConnection MySQL 的 $_GET 方法

javascript - 在 laravel 中获取 ajax 发布的数据?

ajax - 使用 ajax 加载内容时为谷歌爬虫创建默认 View

php - Ajax 在提交时显示消息而不刷新

php - Android:进行 HTTP 调用时使用 cookie 保持服务器 session

javascript - 使用 jQuery 重新加载 div 内容

php - 回显两个用户

c++ - WinInet 输出中的随机字符

multithreading - 从数据中获取 session