无法使用Slim Framework从PUT请求获得响应

时间:2016-11-09 15:09:06

标签: php mysql phpstorm slim

我试图使用PUT请求更新我的数据库中的现有实体,但我有2个问题,当我从phpStorm调用请求时,客户端调试器出现错误

{"error":true,"message":"Required field(s) restaurant_id, service_rating, food_rating, music_rating is missing or empty"}

当我在Google Chrome上调用来自Advance rest client addon的相同请求时

{"error":true,"message":"Task failed to update. Please try again!"}

所以我无法理解真正的错误是在verifyRequiredParams上还是在我的函数实现中。如果有人可以帮助我,我会提供代码。

这是我的index.php文件

$app->put('/userRatings/:rating_id', 'authenticate', function($rating_id) use($app) {
// check for required params

verifyRequiredParams(array('restaurant_id', 'service_rating', 'food_rating', 'music_rating'));

global $user_id;
$restaurant_id = $app->request->put('restaurant_id');
$service_rating = $app->request->put('service_rating');
$food_rating = $app->request->put('food_rating');
$music_rating = $app->request->put('music_rating');



$db = new DbHandler();
$response = array();

// updating rating
$result = $db->updateRating($user_id, $rating_id, $restaurant_id, $service_rating, $food_rating, $music_rating);

if ($result) {
    // rating updated successfully
    $response["error"] = false;
    $response["message"] = "Task updated successfully";
} else {
    // task failed to update
    $response["error"] = true;
    $response["message"] = "Task failed to update. Please try again!";
}
echoRespnse(200, $response);
});

这是verifyRequiredParams的功能代码,它位于index.php文件中

function verifyRequiredParams($required_fields) {
$error = false;
$error_fields = "";
$request_params = array();
$request_params = $_REQUEST;
// Handling PUT request params
if ($_SERVER['REQUEST_METHOD'] == 'PUT') {
    $app = \Slim\Slim::getInstance();
    parse_str($app->request()->getBody(), $request_params);
}
foreach ($required_fields as $field) {
    if (!isset($request_params[$field]) || strlen(trim($request_params[$field])) <= 0) {
        $error = true;
        $error_fields .= $field . ', ';
    }

}
if ($error) {
    // Required field(s) are missing or empty
    // echo error json and stop the app
    $response = array();
    $app = \Slim\Slim::getInstance();
    $response["error"] = true;
    $response["message"] = 'Required field(s) ' . substr($error_fields, 0, -2) . ' is missing or empty';
    echoRespnse(400, $response);
    $app->stop();
}
}

这是函数所在的DbHandler.php文件。

public function updateRating( $user_id, $rating_id, $restaurant_id, $service_rating, $food_rating, $music_rating) {
    $stmt = $this->conn->prepare("UPDATE  user_ratings set  service_rating = ?, food_rating = ?, music_rating = ? WHERE user_id = ? AND rating_id = ? AND restaurant_id = ?");
    $stmt->bind_param("iiiiii", $user_id , $rating_id, $restaurant_id, $service_rating, $food_rating, $music_rating);
    $stmt->execute();
    $num_affected_rows = $stmt->affected_rows;
    $stmt->close();
    return $num_affected_rows > 0;
} 

我所有的连接都没问题我已经检查了它们,我的其他服务也正常工作

2 个答案:

答案 0 :(得分:0)

这两个错误是因为提前休息的客户使用&#34; PUT&#34;大写字母和php风暴与较低的字符,即使它在php风暴中写入资本我注意到通过改变&#34; PUT&#34;与&#34; put&#34;在verifyRequiredParams函数的if语句中,现在它的工作和更新完美

答案 1 :(得分:0)

在 index.php 文件中添加波纹管代码

$app->addBodyParsingMiddleware();