当前位置: 首页 > 面试题库 >

如何设置Cookie,然后在PHP中重定向?

周玺
2023-03-14
问题内容

经过一些处理后,我想为用户输入设置一个cookie值,然后将其重定向到新页面。但是,cookie尚未设置。如果我注释掉重定向,则cookie设置成功。我认为这是某种形式的标题问题。在这种情况下最好的解决方法是什么?

if($form_submitted) {
    ...
    setcookie('type_id', $new_type_id, time() + 60*60*24*30);
    header("Location: $url");
    exit;
}

请注意,true无论哪种情况,setcookie都会返回,并且我不会收到任何错误/警告/通知。

编辑: 我正在使用Unix / Apache / MySQL / PHP


问题答案:

如果您拥有人工网址或子文件夹(例如www.domain.com/path1/path2/),则必须将cookie路径设置为/才能适用于所有路径,而不仅仅是当前路径。

if($form_submitted) {
    ...
    setcookie('type_id', $new_type_id, time() + 60*60*24*30, '/');
    header("Location: $url");
    exit;
}

从PHP手册:

Cookie在服务器上可用的路径。如果设置为“ /”,则cookie将在整个域中可用。如果设置为’/ foo /’,则cookie仅在/ foo
/目录以及domain的所有子目录(如/ foo / bar /)内可用。默认值为正在设置Cookie的当前目录。



 类似资料:
  • 问题内容: 在Flask中,似乎可以通过直接修改响应对象来设置Cookie。 如何成功返回响应对象,又如何在成功登录后将用户重定向到其他页面?我想专门重定向用户,而不是渲染其他页面,以防用户点击REFRESH。 这是我当前的代码,它仅显示同一页面login.html: 问题答案: 你应该将代码更改为:

  • 问题内容: 我在尝试在 Liferay 6.0 portlet中 设置会话cookie时遇到问题。我希望能够将cookie设置为客户端浏览器,以存储用于linkedin身份验证的应用程序密钥,然后可以在其中通过其他portlet检索它。 我可以使用以下方法读取Cookie: 这是我阅读失败的尝试。 问题答案: 我发现,无需大量修改Liferay门户本身,设置portlet cookie的唯一方法就

  • 问题内容: 最初,我使用以下ajax设置cookie。 现在,我想使用servlet的添加cookie函数来设置cookie。但是我不知道如何实现我的目标。 为了延长Cookie的时间限制,我应该在React端写些什么来接收Cookie的会话时间? 问题答案: 看来以前在npm软件包中存在的功能已移至。现在,来自通用Cookie存储库的相关示例是:

  • 我正在尝试使用 accessToken 和 refreshToken 实现 JWT 授权。访问令牌和刷新令牌都需要在仅限HTTP的cookie中设置。 我尝试了这段代码,但它没有设置cookie。我在这里使用NestJS框架。 res.send()方法运行良好,我正在获取数据作为响应。如何在此处设置cookie? 这是我的主要内容。ts文件:- 为了获得我正在使用的cookie:-

  • MvcConfig方法如下所示:

  • 完整的请求链是: > : 或(似乎无关紧要): ,因为此时站点是相同的,并且浏览器显示cookie 对于用户上次加载的页面不在上的一般情况,我赞赏将呈现给的CSRF潜力,但我只是将其从设置,现在我是重定向到的人。 当然,我可以设置,但是如果有人可以找到某种方法通过错误地创建URL来触发他们从我的站点选择的重定向,那么就不会有点击劫持的可能吗?