我在Android中有一个非常基本的注册脚本,但Android无法连接到我的本地主机phpmyadmin数据库(XAMPP)。
有人告诉我这可能是我的XAMPP设置,或者我使用了错误的URL,或者我的脚本中需要一个超时块。我已经经历了很多调试方法,但是我得到的唯一结果是
/创建用户:com.android.volley.NoConnectionError: java.io.EOFException。
现在,即使该错误也消失了。我没有任何错误,我的脚本什么也不做。
这是我的CreateUser脚本;
public class CreateUser extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_create_user);
this.setTitle("Create User");
final EditText username1 = findViewById(R.id.Createusername);
final EditText password1 = findViewById(R.id.CreatePassword);
final Switch isAdmin = findViewById(R.id.isadmin);
final Button createuser = findViewById(R.id.createuserbtn);
if (getIntent().hasExtra("com.example.northlandcaps.crisis_response")){
isAdmin.setVisibility(View.GONE);
}
createuser.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
final String username = username1.getText().toString();
final String password = password1.getText().toString();
if (isAdmin.getShowText()) {
Global.isadmin = "1";
}else{
Global.isadmin ="0";
}
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(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();
}
} catch (JSONException e) {
e.printStackTrace();
}
}
};
int socketTimeout = 250000;//30 seconds - change to what you want
RetryPolicy policy = new DefaultRetryPolicy(socketTimeout, DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT);
RegisterRequest registerRequest = new RegisterRequest(username,password,Global.isadmin,responseListener);
registerRequest.setRetryPolicy(policy);
RequestQueue queue = Volley.newRequestQueue(CreateUser.this);
queue.add(registerRequest);
}
});
}
这是我的RegisterRequest类;
public class RegisterRequest extends StringRequest {
private static final String REGISTER_REQUEST_URL = "http://10.0.2.2:3306/phptesting/Register.php"; //the address was localhost, then my ipaddress, and now its this code i was told to put in
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<String, String>();
params.put("username",username);
params.put("password",password);
params.put("isAdmin", isAdmin);
}
public Map<String, String> getparams() {
return params;
}
}
,如果需要,这是XAMPP中htdocs中的PHP脚本。
<?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"];
$username = $_POST["username"];
$password = $_POST["password"];
$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, "sss",$username,$password,$isAdmin);
mysqli_stmt_execute($statement);
if(mysqli_error($statement)) { return json_encode(['status'=>'failed','message'=>mysqli_error($con)]); }
$response = array();
$response["success"] = true;
echo json_encode($response);
?>
我感谢所有帮助,如果有人要和我一起尝试创建这个简单的登录和注册应用程序,我将非常乐意。
答案 0 :(得分:1)
由于在代码中使用了错误的URL,您会收到错误消息。
private static final String REGISTER_REQUEST_URL = "http://10.0.2.2:3306/phptesting/Register.php";
我不确定您是否知道。端口号3306
为MySQL数据库引擎保留。在哪里,Apache服务器可以在端口号80
或任何其他端口上运行(如果已配置为使用其他端口号)。
现在,您需要将该URL更改为以下内容(只需删除:3306
)。
private static final String REGISTER_REQUEST_URL = "http://10.0.2.2/phptesting/Register.php";
请记住,此URL(10.0.2.2
)仅适用于Android模拟器,不适用于真实设备。因此,我建议您使用系统(LAN)IP地址,该地址在模拟器和真实设备上均能正常工作。
如何检查IP地址?
首先将您的系统和电话(或仿真器)连接到同一WiFi网络或移动热点。
然后打开命令提示符,键入ipconfig
,它将返回如下所示的输出
C:\Users\user_name>ipconfig
Windows IP Configuration
Wireless LAN adapter Wireless Network Connection 2:
Media State . . . . . . . . . . . : Media disconnected
Connection-specific DNS Suffix . :
Wireless LAN adapter Wireless Network Connection:
Connection-specific DNS Suffix . :
Link-local IPv6 Address . . . . . : ******
IPv4 Address. . . . . . . . . . . : 192.168.1.141
Subnet Mask . . . . . . . . . . . : 255.255.255.0
Default Gateway . . . . . . . . . : ******
192.168.*.*
Ethernet adapter Local Area Connection:
Media State . . . . . . . . . . . : Media disconnected
Connection-specific DNS Suffix . :
Tunnel adapter isatap.{******}:
Media State . . . . . . . . . . . : Media disconnected
Connection-specific DNS Suffix . :
C:\Users\user_name>
现在检查
Wireless LAN adapter Wireless Network Connection:
Connection-specific DNS Suffix . :
Link-local IPv6 Address . . . . . : ******
IPv4 Address. . . . . . . . . . . : 192.168.1.141
Subnet Mask . . . . . . . . . . . : 255.255.255.0
Default Gateway . . . . . . . . . : ******
192.168.1.1
复制IPv4地址192.168.1.141
并准备一个这样的URL
private static final String REGISTER_REQUEST_URL = "http://192.168.1.141/phptesting/Register.php";
IP地址因系统而异。另外请记住,要获取IP地址,您应该将系统连接到WiFi(或LAN)网络。
我已经将Apache端口地址配置为其他地址,URL看起来像这样
private static final String REGISTER_REQUEST_URL = "http://192.168.1.141:80/phptesting/Register.php";
其中端口号为80
答案 1 :(得分:0)
此Android: Volley NoConnectionError将为您提供帮助。您的IP地址和端口很可能不正确。您可以通过在移动(仿真器)浏览器中输入IP地址和端口来检查它,然后检查它是否正确加载。如果找不到适合您应用程序的正确IP地址和端口。
可能有模拟器和您的xampp服务器不在同一网络中。您还可以检查并尝试浏览您的移动地址中的IP地址和端口。