摘要
我们正在编写单元测试,以测试JWT令牌的创建和失效,并且每次尝试使用JWTAuth::invalidate使令牌失效时都会收到“无法从请求中解析令牌”的JWTException错误。
描述
在我们的控制器内,为了创建用户令牌,我们通过传递用户电子邮件地址并返回JWT令牌来实现。
之后,我们使用invalidateToken方法销毁令牌,并通过发送Authorization标头传递令牌来使其无效。
public function invalidateToken()
{
try {
JWTAuth::invalidate(JWTAuth::getToken());
return Response::json(['status' => 'success'], 200);
} catch (JWTException $e) {
return Response::json(['status' => 'error', 'message' => $e->getMessage()], 401);
}
}
使用Postman和PHPStorm的Restful客户端都可以完美地运行此功能。
当我们尝试为此方法编写测试时,我们会遇到一个错误响应和“无法从请求中解析令牌”的错误消息。
我们的测试如下:
public function testInvalidateToken()
{
$createUserToken = $this->call('POST', '/token/create', ['email' => 'test@test.com']);
$user = $this->parseJson($createUserToken);
$response = $this->call('POST', '/token/invalidate',
[/* params */], [/* cookies */], [/* files */], ['HTTP_Authorization' => 'Bearer '.$user->token]);
// var_dump($user->token);
// die();
$data = $this->parseJson($response);
$this->assertEquals($data->status, 'success');
$this->assertEquals($data->status, '200');
}
我们正在使用Laravel 5.1(其中cookies作为服务器参数之前的参数)。
PHP版本为5.6.10。
PHPUnit版本为3.7.28。 *编辑* 已更新至PHPUnit 4.7.6,仍无法发送授权标头。 *解决方案*
在我的控制器__construct方法中,我有这几行代码正在运行并解决了我的问题。
if ((\App::environment() == 'testing') && array_key_exists("HTTP_Authorization", Request::server())) {
JWTAuth::setRequest(\Route::getCurrentRequest());
}