Параметры для входа в систему без публикации через REST с использованием Volley

1

Я пытаюсь получить приложение Android Demo Login для входа через REST на мой сервер с приложением login.php, которое запрашивает локальную базу данных MySQL на сервере.

Когда я запускаю REST Query from Insomnia, я указываю следующий массив JSON:

{
    "email": "[email protected]",
    "password": "hello"
}

И тогда на ответ я получаю следующее:

{
  "login": [
    {
      "name": "Chuck",
      "email": "[email protected]",
      "id": "0"
    }
  ],
  "success": "1",
  "message": "success"
}

Однако в Android я получаю нулевой ответ, который я получу, если не укажу массив JSON. Вот как выглядит мой LoginActivity:

package com.dafakamatt.androidregisterandlogin;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;

import com.android.volley.AuthFailureError;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.util.HashMap;
import java.util.Map;

public class LoginActivity extends AppCompatActivity {

    private EditText email, password;
    private Button btn_login;
    private TextView link_regist;
    private ProgressBar loading;
    private static String URL_LOGIN = "http://192.168.69.3/android_register_login/login.php";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);

        loading = findViewById(R.id.loading);
        email = findViewById(R.id.email);
        password = findViewById(R.id.password);
        btn_login = findViewById(R.id.btn_login);
        link_regist = findViewById(R.id.link_regist);

        btn_login.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String mEmail = email.getText().toString().trim();
                String mPass = password.getText().toString().trim();


                if (!mEmail.isEmpty() || !mPass.isEmpty()) {
                    Login(mEmail, mPass);

                } else {
                    email.setError("Please insert email");
                    password.setError("Please insert password");
                }
            }
        });

        link_regist.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                startActivity(new Intent(LoginActivity.this,RegisterActivity.class));
            }
        });

    }

    private void Login(final String email, final String password) {

        loading.setVisibility(View.VISIBLE);
        btn_login.setVisibility(View.GONE);

        StringRequest stringRequest = new StringRequest(Request.Method.POST, URL_LOGIN,
                new Response.Listener<String>() {
                    @Override
                    public void onResponse(String response) {
                        try {
                            JSONObject jsonObject = new JSONObject(response);
                            String success = jsonObject.getString("success");
                            JSONArray jsonArray = jsonObject.getJSONArray("login");

                            if (success.equals("1")) {
                                for (int i = 0; i < jsonArray.length(); i++) {

                                    JSONObject object = jsonArray.getJSONObject(i);

                                    String name = object.getString("name").trim();
                                    String email = object.getString("email").trim();

                                    Toast.makeText(LoginActivity.this,
                                            "Success Login. \nYour Name: "
                                                    + name + "\nYour Email: "
                                                    + email, Toast.LENGTH_SHORT)
                                            .show();
                                    loading.setVisibility(View.GONE);

                                }
                            }

                        } catch (JSONException e) {
                            e.printStackTrace();
                            loading.setVisibility(View.GONE);
                            btn_login.setVisibility(View.VISIBLE);
                            Toast.makeText(LoginActivity.this, "Error " + e.toString(), Toast.LENGTH_SHORT).show();
                        }
                    }
                },
                new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {
                        loading.setVisibility(View.GONE);
                        btn_login.setVisibility(View.VISIBLE);
                        Toast.makeText(LoginActivity.this, "Error -" + error.toString(), Toast.LENGTH_SHORT).show();
                    }
                }) {
            @Override
            protected Map<String, String> getParams() {
                Map<String, String> params = new HashMap<>();
                params.put("email",email);
                params.put("password",password);
                return params;
            }
        };

        RequestQueue requestQueue = Volley.newRequestQueue(this);
        requestQueue.add(stringRequest);

    }
}

Я предполагаю, что переопределенный метод getParams() не выполняет свою работу, потому что я сделал что-то неправильно.

Мой журнал сбоев здесь при попытке войти в систему:

W/System.err: org.json.JSONException: End of input at character 0 of 
        at org.json.JSONTokener.syntaxError(JSONTokener.java:449)
W/System.err:     at org.json.JSONTokener.nextValue(JSONTokener.java:97)
        at org.json.JSONObject.<init>(JSONObject.java:159)
        at org.json.JSONObject.<init>(JSONObject.java:176)
        at com.dafakamatt.androidregisterandlogin.LoginActivity$3.onResponse(LoginActivity.java:83)
        at com.dafakamatt.androidregisterandlogin.LoginActivity$3.onResponse(LoginActivity.java:79)
        at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:78)
        at com.android.volley.toolbox.StringRequest.deliverResponse(StringRequest.java:30)
        at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:106)
        at android.os.Handler.handleCallback(Handler.java:790)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)

Это файл AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.dafakamatt.androidregisterandlogin">

    <uses-permission android:name="android.permission.INTERNET" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppThemeLogin"
        android:usesCleartextTraffic="true">
        <activity android:name=".LoginActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".RegisterActivity"
            android:theme="@style/AppThemeRegist">

        </activity>
    </application>

</manifest>

Это код php:

<?php

// required headers
header("Access-Control-Allow-Origin: *");
header("Content-Type: application/json; charset=UTF-8");



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

    $json = file_get_contents('php://input');
    $obj = json_decode($json);

    $email  = $obj->{'email'};
    $password = $obj->{'password'};

    require_once 'connect.php';

    $sql = "SELECT * FROM users_table WHERE email='" . $email . "' ";

    $response = mysqli_query($conn, $sql);

    $result = array();
    $result['login'] = array();

    if ( mysqli_num_rows($response) === 1 ) {

        $row = mysqli_fetch_assoc($response);

        if ( password_verify($password, $row['password']) ) {

            $index['name'] = $row['name'];
            $index['email'] = $row['email'];
            $index['id'] = $row['id'];

            array_push($result['login'], $index);

            $result['success'] = "1";
            $result['message'] = "success";
            echo json_encode($result);

            mysqli_close($conn);

        } else {

            $result['success'] = "0";
            $result['message'] = "error";
            echo json_encode($result);

            mysqli_close($conn);

        }

    } 


}

?>

и require_once connect.php:

<?php

$conn = mysqli_connect("localhost", "sql", "P@ssw0rd", "users");

?>

Любая помощь приветствуется:

NB. Я следую этому руководству: https://www.youtube.com/watch?v=yS5n40h4Wlg&t=0s.

Теги:
android-volley

2 ответа

1

Я хочу сказать вам одну вещь об этом exception:

org.json.JSONException: конец ввода с символом 0 в org.json.JSONTokener.syntaxError(JSONTokener.java:449)

Это означает, что вы не получаете никакого ответа JSON. Вам нужно отладить свой код, чтобы выяснить, почему это происходит.

Я думаю, что у него есть некоторые проблемы с бэкендом.

РЕДАКТИРОВАТЬ :

    if ( password_verify($password, $row['password']) ) {

        $index['name'] = $row['name'];
        $index['email'] = $row['email'];
        $index['id'] = $row['id'];

        array_push($result['login'], $index);

        $result['success'] = "1";
        $result['message'] = "success";
        return json_encode($result);

        mysqli_close($conn);

    } else {

        $result['success'] = "0";
        $result['message'] = "error";
        return json_encode($result);

        mysqli_close($conn);

    }
  • 0
    Комментарии не предназначены для расширенного обсуждения или отладки; этот разговор был перенесен в чат . Пожалуйста, не забудьте отредактировать ответ, включив в него всю необходимую информацию.
  • 0
    Привет Abinav, этот код PHP работает при использовании бессонницы и указании параметров в теле JSON
Показать ещё 4 комментария
0

Если вы обнаружили, что он работает с тестовым клиентом, а не с вашим клиентом (приложением), убедитесь, что запрошенная полезная нагрузка одинакова. Как правило, существует некоторая разница в заголовках http, которая привлекает внимание пользователей.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню