Android未连接到本地主机或计算机IP地址

时间:2018-11-05 01:54:24

标签: java php android xampp

我在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);
    ?>

我感谢所有帮助,如果有人要和我一起尝试创建这个简单的登录和注册应用程序,我将非常乐意。

2 个答案:

答案 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地址和端口。