Получить ответ об ошибке от Android с JSON/PHP
Я пишу свое приложение для Android, которое разделяет таблицы БД с форумом PHP на моем локальном сервере. Пользователи моего приложения должны зарегистрироваться, прежде чем он / она сможет начать использовать приложение, и одна из функций в моем приложении - разрешить этим зарегистрированным пользователям отправлять / просматривать сообщения и комментарии на форуме, все из интерфейса приложения Android не позвонив по всему форуму в мой телефон, но я использовал JSON в этой задаче с разными ответами. К сожалению, каждый раз, когда я регистрируюсь, я получаю ответ об ошибке, но я не мог понять, почему
это ответ об ошибке, который я получил
03-14 16:14:52.361: E/JSON(400): {"tag":"register","success":0,"error":1,"error_msg":"Error occured in Registartion"}
а это мой index.php
<?php
/**
* File to handle all API requests
* Accepts GET and POST
*
* Each request will be identified by TAG
* Response will be JSON data
/**
* check for POST request
*/
if (isset($_POST['tag']) && $_POST['tag'] != '') {
// get tag
$tag = $_POST['tag'];
// include db handler
require_once 'include/DB_Functions.php';
$db = new DB_Functions();
// response Array
$response = array("tag" => $tag, "success" => 0, "error" => 0);
// check for tag type
if ($tag == 'login') {
// Request type is check Login
$email = $_POST['email'];
$password = $_POST['password'];
// check for user
$user = $db->getUserByEmailAndPassword($email, $password);
if ($user != false) {
// user found
// echo json with success = 1
$response["success"] = 1;
$response["id"] = $user["unique_id"];
$response["user"]["name"] = $user["username"];
$response["user"]["email"] = $user["email"];
$response["user"]["created_at"] = $user["created_at"];
$response["user"]["updated_at"] = $user["updated_at"];
echo json_encode($response);
} else {
// user not found
// echo json with error = 1
$response["error"] = 1;
$response["error_msg"] = "Incorrect email or password!";
echo json_encode($response);
}
} else if ($tag == 'register') {
// Request type is Register new user
$name = $_POST['username'];
$email = $_POST['email'];
$password = $_POST['password'];
// check if user is already existed
if ($db->isUserExisted($email)) {
// user is already existed - error response
$response["error"] = 2;
$response["error_msg"] = "User already existed";
echo json_encode($response);
} else {
// store user
$user = $db->storeUser($name, $password, $email);
if ($user) {
// user stored successfully
$response["success"] = 1;
$response["id"] = $user["unique_id"];
$response["user"]["name"] = $user["username"];
$response["user"]["email"] = $user["email"];
$response["user"]["created_at"] = $user["created_at"];
$response["user"]["updated_at"] = $user["updated_at"];
echo json_encode($response);
} else {
// user failed to store
$response["error"] = 1;
$response["error_msg"] = "Error occured in Registartion";
echo json_encode($response);
}
}
} else {
echo "Invalid Request";
}
} else {
echo "Access Denied";
}
?>
это моя STOREUSERFUNCTION
public function storeUser($name, $password, $email) {
$uuid = uniqid('', true);
$hash = $this->hashSSHA($password);
$encrypted_password = $hash["encrypted"]; // encrypted password
$salt = $hash["salt"]; // salt
$result = mysql_query("INSERT INTO user(unique_id, username, password, salt, email, created_at) VALUES('$uuid', '$name', '$encrypted_password', '$salt', '$email', NOW())");
// check for successful store
if ($result) {
// get user details
$id = mysql_insert_id(); // last inserted id
$result = mysql_query("SELECT * FROM user WHERE id = $id");
// return user details
return mysql_fetch_array($result);
} else {
return false;
}
}
Я действительно не мог понять, что здесь не так, так как раньше я мог запустить его нормально, но теперь я изменяю этот код, чтобы сохранить детали в пользовательской таблице форума, чтобы я мог иметь дело с одной таблицей для пользовательских данных, и я чувствую себя довольно комфортно с новым код здесь - я имею в виду, я думаю, что это не причина ответа на ошибку - но я сомневаюсь с таблицей, но в любом случае я не уверен, где ошибка, которая вызывает ответ об ошибке
1 ответ
Хорошо, ребята, теперь я исправил это нормально, никаких проблем, это была функция на моей стороне Android, которая делает запрос на вход в систему, ее параметры не установлены в порядке, соответствующем порядку функции в моем файле php. большое спасибо чувак особая благодарность karmafunk вы мне очень помогли, что вы все самое лучшее
надеюсь, мой вопрос поможет другим с тем же вопросом.