Ich habe diese einfache REST api, die in Slim erstellt wurde,
<?php
require '../vendor/autoload.php';
function getDB()
{
$dsn = 'sqlite:/home/branchito/personal-projects/slim3-REST/database.sqlite3';
$options = array(
PDO::ATTR_PERSISTENT => true,
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
);
try {
$dbh = new PDO($dsn);
foreach ($options as $k => $v)
$dbh->setAttribute($k, $v);
return $dbh;
}
catch (PDOException $e) {
$error = $e->getMessage();
}
}
$app = new \Slim\App();
$app->get('/', function($request, $response) {
$response->write('Bienvenidos a Slim 3 API');
return $response;
});
$app->get('/getScore/{id:\d+}', function($request, $response, $args) {
try {
$db = getDB();
$stmt = $db->prepare("SELECT * FROM students
WHERE student_id = :id
");
$stmt->bindParam(':id', $args['id'], PDO::PARAM_INT);
$stmt->execute();
$student = $stmt->fetch(PDO::FETCH_OBJ);
if($student) {
$response->withHeader('Content-Type', 'application/json');
$response->write(json_encode($student));
} else { throw new PDOException('No records found');}
} catch (PDOException $e) {
$response->withStatus(404);
$err = '{"error": {"text": "'.$e->getMessage().'"}}';
$response->write($err);
}
return $response;
});
$app->run();
ich kann jedoch nicht den Browser zum Senden von application/json
-Inhaltstypen veranlassen, es sendet immer text/html
? Was mache ich falsch?
EDIT:
Ok, nachdem ich den Kopf zwei Stunden gegen die Wand geschlagen hatte, stolperte ich über diese Antwort:
https://github.com/slimphp/Slim/issues/1535 (am Ende einer Seite) Was erklärt, was passiert, scheint, dass das response
-Objekt unveränderlich ist und so muss es sein zurückgegeben oder neu zugewiesen, wenn Sie es nach zurückgeben möchten.
Also stattdessen:
if($student) {
$response->withHeader('Content-Type', 'application/json');
$response->write(json_encode($student));
return $response;
} else { throw new PDOException('No records found');}
Mach das so:
if($student) {
return $response->withStatus(200)
->withHeader('Content-Type', 'application/json')
->write(json_encode($student));
} else { throw new PDOException('No records found');}
Und alles ist gut und gut.
Für V3 ist withJson()
verfügbar.
So kannst du so etwas tun:
return $response->withStatus(200)
->withJson(array($request->getAttribute("route")
->getArgument("someParameter")));
Hinweis: Stellen Sie sicher, dass Sie den $response
zurückgeben. Wenn Sie dies vergessen, wird die Antwort trotzdem ausgegeben, jedoch nicht application/json
.
Für V3 lautet die einfachste Methode gemäß Slim docs :
$data = array('name' => 'Rob', 'age' => 40);
return $response->withJson($data, 201);
Dadurch wird der Content-Type automatisch auf application/json;charset=utf-8
gesetzt und Sie können auch einen HTTP-Statuscode festlegen (Standardeinstellung ist 200, wenn er weggelassen wird).
Sie können auch verwenden:
$response = $response->withHeader('Content-Type', 'application/json');
$response->write(json_encode($student));
return $response;
weil withHeader
neues Antwortobjekt zurückgibt. Auf diese Weise haben Sie mehr als einen Schreibvorgang und Code dazwischen.