我试图使用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;
}
我所有的连接都没问题我已经检查了它们,我的其他服务也正常工作
答案 0 :(得分:0)
这两个错误是因为提前休息的客户使用&#34; PUT&#34;大写字母和php风暴与较低的字符,即使它在php风暴中写入资本我注意到通过改变&#34; PUT&#34;与&#34; put&#34;在verifyRequiredParams函数的if语句中,现在它的工作和更新完美
答案 1 :(得分:0)
在 index.php 文件中添加波纹管代码
$app->addBodyParsingMiddleware();