Ответить на запрос http получить с помощью объекта json в php

У меня есть страница PHP (test.php), которая должна ответить на запрос HTTP GET, отправленный из приложения Android. Ответ должен быть через объект json. Как я могу это сделать?

Для справки:- Ниже приведен php-код, который проверяет данные для входа в форму для входа. Http-запросом будет имя пользователя и пароль, отправленные из приложения для Android, которое содержит форму входа в систему. Ответом на этой странице будет сообщение об успехе или неудаче.

<?php
        session_start();
         require('connect.php');
        if (isset($_GET['username']) and isset($_GET['password']))
        {
            $username = $_GET['username'];
            $password = $_GET['password'];
            $query = "SELECT * FROM `staff_reg` WHERE username='$username' and password='$password'";

            $result = mysql_query($query) or die(mysql_error());
            $count = mysql_num_rows($result);
            if ($count == 1)
            {
                $_SESSION['username'] = $username;
            }
            else
            {
                echo "Invalid Username or Password";
            }
        }
        if (!isset($_SESSION['username']))
        {
            echo "Session Expired";
            echo "<br><a href='staff_login.php'>Click here</a> to login again"; 
            echo "<br><a href='index.html'>Click here</a> to go back to the homepage"; 
            $username = $_SESSION['username'];
        }
        else{
            $username = $_SESSION['username'];
            echo "<p>Welcome ".$username."<br>";
            echo "This is the Staff Portal<br>";
            echo "<a href='logout.php'>Logout</a></p>"; 
    ?>

3 ответа

Решение

Я думаю, что это может помочь вам..

<?php
        session_start();
         require('connect.php');
        //create an variable $response
        //Use GET instead of POST since you are sending data in GET method
        if (isset($_GET['username']) and isset($_GET['password']))
        {
            $username = $_GET['username'];
            $password = $_GET['password'];
            $query = "SELECT * FROM `staff_reg` WHERE username='$username' and password='$password'";

            $result = mysql_query($query) or die(mysql_error());
            $count = mysql_num_rows($result);
            if ($count == 1)
            {
                $response="Success";
            }
            else
            {
                $response="Failure";
            }
        //now echo it as an json object
            echo json_encode($response);
        }

Вы можете отправить свой ответ в виде данных, закодированных в json, например, скажем, ваши данные ответа

$user = array('firstName' =>'abc', 'lastName' =>'xyz'); 
$response = json_encode($user);

Если это API для приложения Android, которое вы упомянули, то вы не можете использовать сессии в нем. Вы должны найти другой способ авторизации пользователя.

Вы можете кодировать свои строки и массивы в формате json, но вам лучше создать объект и кодировать его. Таким образом, вы можете получить доступ к значениям по имени, указанному в API.

Например:

$obj->status = "error";

Или же

$obj->status = "success";

И в конце:

echo json_encode($obj);

И вы можете получить к нему доступ в приложении с этим форматом:

   //String response = httpResponse
   JsonObject object = new JsonObject(response);
   String status = object.getString("status");
   if(status.equals("error")){
        //handle the error
   } else {
        //login was successful and you can show the user the proper activity
   }

Что касается отправки запроса в API, я рекомендую использовать библиотеку AQuery.

Библиотека может упростить вашу работу с http-запросами. это работает следующим образом:

    AQuery aq = new AQuery(context);
    aq.ajax(url, JsonObject.class, new AjaxCallback<JsonObject>(){
    @Override
    public void callback(String url, JSONObject object, AjaxStatus status) {
        //object is the json object sent from the server
    }
    });

Я надеюсь, это поможет вам

Другие вопросы по тегам