我正在向一个需要令牌身份验证的远程服务器(Vebra Api)发起curl请求。据我所知,该服务器每小时只允许一个令牌请求。我试图确定我的当前令牌是否有效。
我的方法是发出请求并检查状态是否为200或401。如果我有一个有效的令牌,我可以使用curl_getinfo($ch)成功检查curl信息以获取正确的状态码。然而,如果我的令牌无效,则脚本会在我无法处理错误或处理任何其他代码之前终止 - Firefox报告
这是我的代码问题还是服务器问题?可能有一种方法可以告诉curl函数在这种情况下调用某个函数吗?
代码如下:
我的方法是发出请求并检查状态是否为200或401。如果我有一个有效的令牌,我可以使用curl_getinfo($ch)成功检查curl信息以获取正确的状态码。然而,如果我的令牌无效,则脚本会在我无法处理错误或处理任何其他代码之前终止 - Firefox报告
The connection was reset
。这是我的代码问题还是服务器问题?可能有一种方法可以告诉curl函数在这种情况下调用某个函数吗?
代码如下:
// an invalid token
$token = '1sdfsdfds1RQUlJTTU1GRVdVT0tYUkJsdfsdfsdfdsfsdSEg=';
//Initiate a new curl session
$ch = curl_init($url);
//Don't require header this time as curl_getinfo will tell us if we get HTTP 200 or 401
curl_setopt($ch, CURLOPT_HEADER, 0);
//Provide Token in header
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Authorization: Basic '. $token ) );
// Tell curl to return a string
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
//Execute the curl session
$curlResp = curl_exec($ch);
// -----------------------------------------------------------------------------
// with invalid token script ends here with no chance for me to handle the error
// such as below
// -----------------------------------------------------------------------------
if ($curlResp === FALSE) {
die('yarrrghhh! :(');
//throw new Exception();
}
//Store the curl session info/returned headers into the $info array
$info = curl_getinfo($ch);
//Check if we have been authorised or not
if($info['http_code'] == '401') {
echo 'Token Failed';
var_dump($info);
var_dump($curlResp);
}
elseif ($info['http_code'] == '200') {
echo 'Token Worked';
var_dump($info);
var_dump($curlResp);
}
//Close the curl session
curl_close($ch);
CURLOPT_HEADER, 1
和CURLOPT_NOBODY, 1
。此外,当出现此问题时,您是否在错误日志中有任何记录? - RantyCURLOPT_HTTPAUTH, CURLAUTH_ANY
或CURLOPT_HTTPAUTH, CURLAUTH_BASIC
怎么样?你正在使用认证,但没有告诉 cURL。 - Ranty