java — Android-студия скажет «ожидает, что параметром 1 будет mysqli, объект задан»

У меня есть Android-студия, отправляющая данные в сценарий PHP, и сценарий PHP должен помещать их в локальную базу данных. У меня все мои переменные названы одинаково, но говорят, что переменные PHP еще не определены. Я знаю, что Android Studio довольно глючная, но все не так плохо. Я, наверное, просто ужасен в написании сценариев.

Вот мой скрипт CreateUser (Java / Android). Он должен обрабатывать, если пользователь отправляет данные, он вызывает класс, передает информацию в класс и дает возможность повторить запрос.

createuser.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

final String username = username1.getText().toString();
final String password = password1.getText().toString();
final String isadmin = isAdmin.getText().toString();
Response.Listener<String> responseListener = new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d("Response Value: ", response);
if (response.equals("success")){
Intent intent = new Intent(CreateUser.this, MainActivity.class);
CreateUser.this.startActivity(intent);
}else{
AlertDialog.Builder builder = new AlertDialog.Builder(CreateUser.this);
builder.setMessage("Register Failed")
.setNegativeButton("Retry",null)
.create()
.show();
}
}
};
RegisterRequest registerRequest = new RegisterRequest(username,password,isadmin,responseListener);
RequestQueue queue = Volley.newRequestQueue(CreateUser.this);
queue.add(registerRequest);
}
});

Вот мой RegisterRequest. Он должен обрабатывать данные и отправлять их по указанному URL-адресу:

public class RegisterRequest extends StringRequest {

private static final String REGISTER_REQUEST_URL = "http://192.168.*.*:80/phptesting/Register.php";
private Map<String, String> params;
public RegisterRequest(String username, String password,String isAdmin, Response.Listener<String> listener){
super(Method.POST, REGISTER_REQUEST_URL,listener,null);
params = new HashMap<>();
params.put("username",username);
params.put("password",password);
params.put("isAdmin",isAdmin+"");
}

public Map<String, String> getparams() {
return params;
}
}

И, наконец, вот мой PHP-скрипт, который должен принимать передаваемые данные и отправлять их в базу данных MySQL. (местный):

<?php
$db_host = 'localhost:3306';
$db_user = 'root';
$db_pass = '';
$db_name = 'test';

$con = mysqli_connect($db_host,'user',$db_pass,$db_name);
if($con){
echo "connection successful";
}else{
echo "connection failed";
}

$age = $_POST["isAdmin"]; // line 14
$username = $_POST["username"]; // line 15
$password = $_POST["password"]; // line 16
$statement = mysqli_prepare($con, "INSERT INTO cresidentials (username,password,isAdmin) VALUES (?, ?, ?)");
if(!$statement) { printf("Prepare failed: %s\n", mysqli_error($con)); }
if(!$statement) { return json_encode(['status'=>'failed','message'=>mysqli_error($con)]); }
mysqli_stmt_bind_param($statement, "ssi",$username,$password,$isAdmin);
mysqli_stmt_execute($statement);
if(mysqli_error($statement)) { return json_encode(['status'=>'failed','message'=>mysqli_error($con)]); } //line 22

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

echo json_encode($response);
?>

Я прошу прощения, если это выглядит как еще один дубликат, я попытался включить прошлые ответы в этот код, и в конце концов, я вообще потерял связь с моим локальным хостом. Так что я вернулся и теперь я прошу помощи. Я ценю любую помощь.
Кстати, вывод ошибок (из android logcat) таков; 11-07 20: 51: 23.128 20208-

crisis_response D/Response Value:: connection successful
Notice:  Undefined index: isAdmin in \Register.php on line 14
Notice:  Undefined index: username in \Register.php on line 15
Notice:  Undefined index: password in /Register.php on line 16
Warning:  mysqli_error() expects parameter 1 to be mysqli, object given in \Register.php on line 22   {"success":true}

0

Решение

Задача ещё не решена.

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector