下面是我正在使用的代码。
<?php
use 'Psr'Http'Message'ServerRequestInterface as Request;
use 'Psr'Http'Message'ResponseInterface as Response;
$app = new 'Slim'App;
function handle_response($output, $response){
if($output['status'] === "failed"){
$response = $response->withStatus(400);
$response->getBody()->write(json_encode($output));
}
else{
$response->getBody()->write(json_encode($output));
}
return $response;
}
/* user profile */
$app->get('/user/profile', function (Request $request, Response $response) {
$headers = $request->getHeaders();
foreach ($headers as $name => $values) {
$name . ": " . implode(", ", $values);
}
if ($request->hasHeader('Authorization')) {
$output['token'] = 'yes';
}
else
$output['token'] = $name;
$output['status'] = "success";
return handle_response($output, $response);
});
我正在使用googlechrome中的poster来测试这个REST服务。我将在GET请求的同时传递一个自定义标头"Authorization"。但是,该程序不识别任何自定义标头。
代码块
$headers = $request->getHeaders();
foreach ($headers as $name => $values) {
$name . ": " . implode(", ", $values);
}
仅返回标题"HTTP_ACCEPT_LANGUAGE"。
请帮我弄清楚,这里出了什么问题。
它不是Slim,它被认为是PHP的一个特性。如果您发送的不是有效的HTTP基本授权标头,PHP将无法访问它。您可以通过在.htaccess
文件中添加以下重写规则来解决此问题。
RewriteRule .* - [env=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
另一种方法是使用apache_request_headers()
,但它是Apache特有的,不可移植。