繁体   English   中英

带有POST请求的500个内部服务器错误-Slim框架

[英]500 internal server error with POST request - Slim framework


我正在尝试使用Slim框架构建一个简单的REST应用程序,但是当我尝试执行POST请求时遇到500错误。 到目前为止,我已经实现了两个有效的GET请求。 这是代码:

index.php

require_once '../include/DbHandler.php';
require '.././libs/Slim/Slim.php';

\Slim\Slim::registerAutoloader();

$app = new \Slim\Slim();

$app->get("/", function () {
    echo "<h1>Hello!!!!</h1>";
});

/**
 * Get all the events
 * method GET
 * url /events
 */
$app->get('/events', function() {
    $db = new DbHandler();
    $response = array();

    // fetch events
    $result = $db->getAllEvents();

    if ($result != NULL) {
        $response["error"] = false;
        $response = $result;
        echoResponse(200, $response);
    } else {
        $response["error"] = true;
        $response["message"] = "The requested resource doesn't exists";
        echoResponse(404, $response);
    }
});

$app->get('/event/:id', function ($id) {
    $response = array();
    $db = new DbHandler();

    // fetch event
    $result = $db->getEvent($id);

    if ($result != NULL) {
        $response["error"] = false;
        $response = $result;
        echoResponse(200, $response);
    } else {
        $response["error"] = true;
        $response["message"] = "The requested resource doesn't exists";
        echoResponse(404, $response);
    }
});

$app->post('/events', function() {
    // opening db connection
    $db = new DbConnect();

    //$db = new DbHandler();

    $request = Slim::getInstance()->request();

    //$result = $db->addEvent($request);

    $event = json_decode($request->getBody());

    $img = " ";
    $sql = "INSERT INTO event (title, location, date_event, ageMin, ageMax, groupSize, limited, maxParticipants, joining, description, img, type, language) VALUES (".$event->title.", ".$event->location.", ".$event->date_event.", ".$event->ageMin.", ".$event->ageMax.", ".$event->ageMax.", ".$event->limited.", ".$event->maxParticipants.", ".$event->joining.", ".$event->description.", ".$img.", "$event->type", ".$event->language.")";
    try {
        //$db = $this->conn;
        $conn = $db->connect();
        $result = $conn->query($sql);
        $event->id = $conn->lastInsertId();
        echoResponse(200, $event->id);
    } catch(PDOException $e) {
        echoResponse(404, '{"error":{"text":'. $e->getMessage() .'}}');
    }
});

/**
 * Echoing json response to client
 * @param String $status_code Http response code
 * @param Int $response Json response
 */
function echoResponse($status_code, $response) {
    $app = \Slim\Slim::getInstance();
    // Http response code
    $app->status($status_code);

    // setting response content type to json
    $app->contentType('application/json');

    echo json_encode($response);
}

$app->run();

?>

如前所述,这两个GET方法都可以使用,但是当我尝试使用POST方法使用此数据添加一行时:

{"title": "Test 1", "location": “Rome, Italy", "date_event": "2016-05-12", "time": "22:00:00", "ageMin": 21, "ageMax": 27, "groupSize": "3", "limited": false, "maxParticipants": "", "joining": "2", "description": "Description test 1", "img": "", "type": "hanging out", "language": "Italian/English"}

我收到500 Internal Server Error ,但我不明白为什么。
我在哪里做错了?
谢谢!

您已经错过了$sql分配中"$event->type"周围的串联点。


在开发过程中,我建议您启用添加错误和警告消息的功能

error_reporting(E_ALL);
ini_set('display_errors', 1);

您的代码。

PHP语法检查:解析错误:语法错误,代码在第62行上出现意外的'$ event'(T_VARIABLE)。

比以下更容易理解

500内部服务器错误。

或者,如果您需要检查一小段代码,则可以使用一些在线工具,例如http://phpcodechecker.com/

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM