Как передать параметр, используя метод post, получить ответ от URL и отобразить его в Android, используя gson и volley? - PullRequest
0 голосов
/ 01 ноября 2018

Я хотел бы передать 2 параметра, используя метод POST, и получить ответ от API, разработанного с использованием php. Я хотел бы использовать GSON и Volley для этого.

Я написал один метод и вызвал его в методе onCreate. Это мой класс методов -

private void loadDetailed() {
        //Toast.makeText(DetailedBoatActivity.this, "Called", Toast.LENGTH_SHORT).show();
        Intent i = getIntent();
        Integer boat_id = i.getExtras().getInt("boat_id");
        Integer owner_id = i.getExtras().getInt("owner_id");
        Gson gson = new Gson();
        Map<String, Integer> jsonMap = new HashMap<>();
        jsonMap.put("boat_id", boat_id);
        jsonMap.put("owner_id", owner_id);
        JSONObject jsonObject = new JSONObject(jsonMap);
        Log.d("jsonObject", String.valueOf(jsonObject));
        JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(Request.Method.POST, DETAILED_BOAT_URL, jsonObject, new Response.Listener<JSONObject>() {
            @Override
            public void onResponse(JSONObject response) {
                try {
                    Toast.makeText(DetailedBoatActivity.this, "Try", Toast.LENGTH_SHORT).show();
                    JSONArray array = new JSONArray(response);
                    Log.i("array1", String.valueOf(array));

                } catch (JSONException e) {
                    Toast.makeText(DetailedBoatActivity.this, "Error", Toast.LENGTH_SHORT).show();
                    e.printStackTrace();
                }
            }
        }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {

            }
        });
        Volley.newRequestQueue(this).add(jsonObjectRequest);
    }

Но я не получаю никакого ответа от моего API. Вот мой код -

public function boatDetails($id, $owner_id){
            $stmt = $this->con->prepare("SELECT * FROM `boat_details` WHERE id=".$id);
            $stmt->execute();
            $resultSet = $stmt->get_result();
            $boat_details = array();
            while($result = $resultSet->fetch_assoc()){
                $boat_details[] = $result;
            }

            return $boat_details;   
        }

Я проверил вручную. Я получаю значения в формате JSON, используя приведенный ниже код -

require_once '../includes/dboperations.php';

    $response = array();

    if($_SERVER['REQUEST_METHOD'] == 'POST'){

        //if($_GET['boat_id']){

            $db = new DbOperations();

            $resultSet = $db->boatDetails($_POST['boat_id'], $_POST['owner_id']);

            echo json_encode($resultSet);
        //}
    }

Пожалуйста, помогите мне с передачей параметра и получите ответ для отображения сущностей.

1 Ответ

0 голосов
/ 01 ноября 2018
    String url = URL.LOGIN_URL + "&mail=" + email + "&pass=" + pwd + ""; 
RequestQueue queue;
queue = Volley.newRequestQueue(YOUR_ACTIVITY_NAME.this);
StringRequest req = new StringRequest(Request.Method.GET, url, new Response.Listener<String>() {
            @Override
            public void onResponse(String response) {   }
        }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {

                System.out.println("error ");
                error.printStackTrace();
            }
        });
        queue.add(req);
...