使用 PhP 在 android 和 mysql 之间建立连接时出错

Posted

技术标签:

【中文标题】使用 PhP 在 android 和 mysql 之间建立连接时出错【英文标题】:Getting error while establishing connection between android and mysql using PhP 【发布时间】:2017-11-03 22:07:52 【问题描述】:

我正在创建一个应用程序,它将在 android 应用程序的 card_layout 中显示 mysql 表的数据。

下面提到的是MainActivity.java中的连接代码

private void load_data_from_server(final int id) 
    AsyncTask<Integer,Void,Void> task = new AsyncTask<Integer, Void, Void>() 
        @RequiresApi(api = Build.VERSION_CODES.KITKAT)
        @Override
        protected Void doInBackground(Integer... params) 
            OkHttpClient client = new OkHttpClient();
            Request request = new Request.Builder().url("http://10.10.2.2/develop/php_recyler_demo.php?id="+id).build();
            try 
                Response response = client.newCall(request).execute();

                JSONArray array = new JSONArray(response.body().toString());

                for (int i=0; i<array.length(); i++) 
                    JSONObject object = array.getJSONObject(i);
                    MyData data = new MyData(object.getInt("id"),object.getString("description"),object.getString("image"));
                    data_list.add(data);
                
             catch (IOException e) 
                e.printStackTrace();
             catch (JSONException e) 
                e.printStackTrace();
            
            return null;
        

        @Override
        protected void onPostExecute(Void aVoid) 
            adapter.notifyDataSetChanged();
        
    ;
    task.execute(id);

对于我使用PhP并在XAMPP服务器中以localhost执行的MySQL连接,代码如下:

<?php
    $connection = mysqli_connect("localhost","root","","test");

    //$id = $_GET["id"];
    $id = isset($_GET['id']) ? $_GET['id'] : '';

    $query = "select * from recyclerdb where id between ($id+1) and ($id+4)";

    $result = mysqli_query($connection,$query);

    while ($row = mysqli_fetch_assoc($result)) 
        # code...
        $array[] = $row;
    

    header('Content-type:Application/json');
    echo json_encode($array);
?>

我的表结构如下:

当我使用浏览器运行这个 PhP 文件时,我得到正确的输出为JSON array:

但是如果我使用模拟器在 android studio 中执行我的应用程序

我收到java.net.SocketTimeoutException: connect timed out

我在MainActivity.java 的两行遇到的问题:

AsyncTask&lt;Integer,Void,Void&gt; task = new AsyncTask&lt;Integer, Void, Void&gt;()

Response response = client.newCall(request).execute();

我研究了很长时间,请有人帮助我。

【问题讨论】:

【参考方案1】:

java.net.SocketTimeoutException: connect timed out 表示您无法连接到所需的服务器。

我猜你必须更换模拟器

http://10.10.2.2/

localhost/

【讨论】:

如果我替换本地主机,那么我会得到Caused by: java.net.ConnectException: Connection refused。在我看来,如果我使用 localhost 那么模拟器会自己找到地址,不是吗? @Shambhu 没有必要。请改用 127.0.0.1。 但是通过添加localhost 我得到了connection refused。我现在该怎么办? 添加127.0.0.1后我得到了`java.net.ConnectException: Failed to connect to /127.0.0.1:80'。 @Shambhu 几个愚蠢的问题:1) 模拟器和 XAMPP 在同一台计算机上? 127.0.0.1 是否在浏览器中打开您的脚本?你从哪里拿到10.10.2.2 地址?

以上是关于使用 PhP 在 android 和 mysql 之间建立连接时出错的主要内容,如果未能解决你的问题,请参考以下文章

如何在 json 的帮助下使用 PHP、MySql 在 android 中验证用户登录凭据

使用php从mysql获取数据到android

Android & PHP:使用 PHP 将数据从 Android POST 到 mysql db

Android:无法使用 php 脚本将图像上传到远程 MySql DB

Android GPS使用php在Mysql中保存当前位置

需要使用 PHP 将 android app 生成的纬度和经度值存储到 mySQL 数据库中