У меня есть 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}
Задача ещё не решена.
Других решений пока нет …