Нет ответа от Register.php? - PullRequest
       34

Нет ответа от Register.php?

1 голос
/ 04 ноября 2019

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

У меня было такое, где я мог войти в реестрнажмите кнопку «Зарегистрироваться» и вернитесь на страницу входа. После попытки связать приложение с базой данных нажатие кнопки «Зарегистрировать» ничего не даст, если я не закомментирую раздел «Response.Listener responseListener = new Response.Listener ()» метода onClick.

Итак, похоже, что я не получаю ответ от Register.php. (?)

Когда я закомментирую раздел "Response.Listener responseListener = new Response.Listener ()" метода onClick, яможет заставить вещи случиться. Поэтому я считаю, что сузил проблему до этого раздела кода.

Мой класс RegisterActivity:

public class RegisterActivity extends AppCompatActivity {

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

    final EditText etName = findViewById(R.id.text_register_name);
    final EditText etUsername = findViewById(R.id.text_register_username);
    final EditText etPassword = findViewById(R.id.text_register_password);
    final Button btnRegister = findViewById(R.id.btn_register);

    btnRegister.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            final String name = etName.getText().toString();
            final String username = etUsername.getText().toString();
            final String password = etPassword.getText().toString();

            Response.Listener<String> responseListener = new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    try {
                        JSONObject jsonResponse = new JSONObject(response);
                        boolean success = jsonResponse.getBoolean("success");

                        if (success) {
                            Intent intent = new Intent(RegisterActivity.this, MainActivity.class);
                            RegisterActivity.this.startActivity(intent);
                        }
                        else {
                            AlertDialog.Builder builder = new AlertDialog.Builder(RegisterActivity.this);
                            builder.setMessage("Register Failed").setNegativeButton("Retry", null).create().show();
                        }
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            };

            RegisterRequest registerRequest = new RegisterRequest(name, username, password, responseListener);
            RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this);
            queue.add(registerRequest);
        }
    });
}

Мой класс RegisterRequest:

public class RegisterRequest extends StringRequest {
private static final String REGISTER_REQUEST_URL = "http://bandsearch.000webhostapp.com/public_html/Band/Register.php";
private Map<String, String> params;

public RegisterRequest (String name, String username, String password, Response.Listener<String> listener) {
    super(Method.POST, REGISTER_REQUEST_URL, listener, null);
    params = new HashMap<>();
    params.put("name", name);
    params.put("username", username);
    params.put("password", password);
}

@Override
protected Map<String, String> getParams() throws AuthFailureError {
    return params;
}

My Register.php:

<?php
ini_set('error_reporting', E_ALL);
ini_set('display_errors', true);

$connect = mysqli_connect('localhost', 'id11439356_btpeters', 'demopass', 'id11439356_localmusic');

// $name = "Brent"; //$_POST['name']; 
// $username = "Vegasbrent"; //$_POST['username']; 
// $password = "pass"; //$_POST['password']; 

$name = $_POST['name'];
$username = $_POST['username'];
$password = $_POST['password'];

$statement = mysqli_prepare($connect, "INSERT INTO user (name, username, password) VALUES (?, ?, ?)");
mysqli_stmt_bind_param($statement, "sss", $name, $username, $password);
mysqli_stmt_execute($statement);

$response = array();
$response["success"] = false;

if (mysqli_query($connect, $statement)) {
    $response["success"] = true;   
}

echo json_encode($response);
?>

Я ожидаю, что таблица пользователей в моей базе данных заполнится, когда нажата кнопка «Зарегистрироваться» и приложение вернется на страницу входа, но нажмет «Зарегистрироваться». Кнопка также не работает.

РЕДАКТИРОВАТЬ: я думаю, что я еще больше сузил проблему до раздела $ _POST:

$name = $_POST['name'];
$username = $_POST['username'];
$password = $_POST['password'];

Я могу добавить в таблицу пользователей в базе данных, еслиЯ устанавливаю переменные в строки вместо $ _POST [...]. Это может быть связано с методом getParams, потому что я никогда не вызываю его. Я предположил, что это было вызвано автоматически где-то. Я проверю это и посмотрю, смогу ли я понять это! Любая помощь приветствуется!

EDIT: метод getParams автоматически вызывается Volley. Попытка теперь выяснить, как проверить, вызвал ли Volley метод getParams!

...