Php 在从mysql数据库(Android)中提取数据之前,请确保wamp服务器处于联机状态

Php 在从mysql数据库(Android)中提取数据之前,请确保wamp服务器处于联机状态,php,android,mysql,wamp,wampserver,Php,Android,Mysql,Wamp,Wampserver,在从mysql数据库获取数据之前,我需要确保wamp服务器在线,如果没有,应用程序会告诉用户在提取数据之前先将其在线,这在android中如何实现?好像是离线的android应用程序停止了 连接到数据库的PHP代码是: <?php //receive datatbase Info. from android app $json=$_SERVER['HTTP_JSON']; var_dump($data); $data=json_decode($json); $dbname=$data-&

在从mysql数据库获取数据之前,我需要确保wamp服务器在线,如果没有,应用程序会告诉用户在提取数据之前先将其在线,这在android中如何实现?好像是离线的android应用程序停止了

连接到数据库的PHP代码是:

<?php

//receive datatbase Info. from android app
$json=$_SERVER['HTTP_JSON'];
var_dump($data);
$data=json_decode($json);
$dbname=$data->dbname;
$dbpass=$data->dbpass;
$link=mysql_connect("localhost","root",$dbpass);

if (!$link) {
    echo "error"; 
    die(mysql_error());
}

$db_selected=mysql_select_db($dbname,$link);

if (!$db_selected) {
    die ('error'. mysql_error());
}

mysql_query("set names 'utf8'");
mysql_query("set CHARACTER set 'utf8'",$link);
mb_internal_encoding("UTF-8");

?>
我在内部回答了这个问题,但这也可能是对这个问题的回答。我的解决方案基本上是基于为wamp服务器
80
端口设置
Socket

我在许多项目中使用以下代码:

Socket socket;

// Adjust it to your case, it might be a public IP too
final String host = "192.168.1.X";
final int port = 80;
final int timeout = 30000;   // 30 seconds of timeout

try {
  socket = new Socket();
  socket.connect(new InetSocketAddress(host, port), timeout);
}
catch (UnknownHostException uhe) {
  Log.e("WampSock", "I couldn't resolve the host you've provided!");
}
catch (SocketTimeoutException ste) {
  Log.e("WampSock", "After a reasonable amount of time, I'm not able to connect, your WAMP server is probably down!");
}
catch (IOException ioe) {
  Log.e("WampSock", "Hmmm... Sudden disconnection, probably you should retry once again!");
} 

对于您的问题,一个可能的解决方案是为wamp服务器地址创建一个Http请求,这可以在Android中轻松完成。下面的代码显示了如何为所需的任何URL创建http请求

Thread thread = new Thread(new Runnable(){
        @Override
        public void run() {
            try {
                try {
                    URL url = new URL("http://220.13.81.33");

                    HttpURLConnection urlc = (HttpURLConnection) url.openConnection();
                    urlc.setConnectTimeout(1000 * 5); // mTimeout is in seconds
                    urlc.connect();

                    if (urlc.getResponseCode() == 301) {


                    }
                } catch (MalformedURLException e1) {
                    e1.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                catch (Exception e)
                {

                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    });

    thread.start(); 
很明显,您只是将所需的IP或URL放入URL构造函数中,但您必须注意两个重要事项:

1-要发出请求,您需要使用线程或创建异步任务,或者,如果您不想使用线程,您可以通过在代码中添加以下策略,强制android在android的主进程中处理此类请求。然而,这种解决方案需要SDK版本超过9

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy); 
2-如果您在emulator上工作,并且希望在本地主机上连接,则必须使用此地址
http://10.0.2.2:8080
因为它是Android的本地主机地址

发出connect函数后,将返回响应代码,否则将出现异常。响应代码的解释可在此链接中找到 ,请注意,如果返回的响应代码是301,这意味着使用的将被重定向到给定的URI,这表示Wamp服务器处于联机状态。对于出现的异常,Wamp服务器很可能处于脱机状态。因此,您需要对不同的场景进行一些测试,并查看输出


我希望你一切顺利

这不是简单多了吗

<?php
    $link = @mysql_connect('127.0.0.1','a_userid','a_password');
    $err = mysql_errno();
    switch ($err) {
        case 2002 :
            echo 'Error Start MySQL Please';
            exit;
        case xxxx : // any other possible errors    
             ...

    }
    // MySQL is there so proceed as normal

非常感谢,但是我的问题通过上面接受的答案解决了,我使用async task检查返回的503(服务不可用)的响应代码403(禁止)是否表示wamp服务器处于脱机状态。。。否则wamp服务器在线..真的很感谢,但是我的问题通过上面接受的答案解决了,我使用异步任务检查返回的503(服务不可用)的响应代码403(禁止)是否表示wamp服务器离线。。。否则wamp服务器将处于联机状态。。