如何在Laravel功能测试中设置请求Cookie?解决方法详解

6,082次阅读
没有评论

共计 1546 个字符,预计需要花费 4 分钟才能阅读完成。

在进行 Laravel 功能测试时,通常我们会使用 $this->postJson() 系列方法来测试接口。一般情况下,通过 $this->actingAs() 方法即可解决登录状态的问题。然而,某些特殊情况下,我们需要向 cookie 中添加 token 以保持登录状态。

一开始,我尝试了以下代码:

$header = ['Set-Cookie: token=abc123'];

但发现这并不能实现预期的效果。于是我尝试了另一种方式:

$header = ['Set-Cookie' => 'token=abc123'];

不过,这次也没有成功。只能进一步阅读源码,在 Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php 的 522 行找到了以下代码片段:

return $this->call(
    $method,
    $uri,
    [],
    $this->prepareCookiesForJsonRequest(),
    $files,
    $this->transformHeadersToServerVars($headers),
    $content
);

倒数第二个参数引起了我的注意,transformHeadersToServerVars()?原来,$header 最终会被转换为 $_SERVER 中的数据。这样的话,使用它来传递 cookie 是行不通的。

接着,我注意到第四个参数 prepareCookiesForJsonRequest()。跟踪进去后发现,该方法会判断属性 $this->withCredentials 是否为 true,如果不是则返回空数组。而这个属性默认值为 false。

为了解决传递 cookie 的问题,我需要将 $this->withCredentials 设置为 true。通过调用 withCredentials() 方法可以实现:

$this->withCredentials();

传递 cookie 的问题解决了,但是如何设置 cookie 呢?接下来,我直接在这个类中搜索关键词 ”cookie”,很快就找到了 withUnencryptedCookie() 方法。由于项目并没有使用 Laravel 自带的 cookie 加密功能,所以我决定使用该方法来设置 cookie。

最后一次尝试,果然实现了我想要的效果:

$this->withUnencryptedCookie('cookie_name', $cookieValue)
    ->withCredentials();

通过以上步骤,我们成功地在 Laravel 功能测试中设置了请求的 cookie。使用 withUnencryptedCookie() 方法设置 cookie 的名称和值,同时调用 withCredentials() 方法设置属性 $this->withCredentials 为 true,即可实现预期的效果。

希望这篇文章对你在 Laravel 功能测试中设置请求 cookie 时有所帮助! 文章来源地址 https://www.toymoban.com/diary/laravel/569.html

到此这篇关于如何在 Laravel 功能测试中设置请求 Cookie?解决方法详解的文章就介绍到这了, 更多相关内容可以在右上角搜索或继续浏览下面的相关文章,希望大家以后多多支持 TOY 模板网!

原文地址:https://www.toymoban.com/diary/laravel/569.html

如若转载,请注明出处:如若内容造成侵权 / 违法违规 / 事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于1970-01-01发表,共计1546字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)