从MySQL数据库-Android获取数据之前,请确保WAMP服务器在线



以前要从mySQL数据库中获取数据在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");
?>

但是在Andorid应用中,当没有连接时,它不会收到"错误"(我的意思是当Wamp服务器离线时)?

总而言之,如果有任何方法可以确保WAMP服务器在从数据库启动之前在线之前在线?如果不给用户msg。

我尝试了疲倦的心情,但没有结果,实际上任何帮助都将不胜感激!

可能的解决方案之一是为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。但是,这种解决方案需要SDK版本超过9。

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy); 

2-如果您正在使用仿真器,并且要在本地主机上连接,则必须使用此地址http://10.0.2.2:8080,因为它是Android的本地主机地址。

发出连接函数后,将返回响应代码,否则将出现例外。可以在此链接中找到响应代码的解释 http://en.wikipedia.org/wiki/list_of_http_status_codes,请注意,如果返回的响应代码为301,则表示所使用的响应代码将重定向到给定的URI,并且这是Wamp Sever在线的指示。对于出现的例外,很可能Wamp服务器离线。因此,您需要针对不同方案进行多次测试并查看输出。

我希望你一切顺利。

我在另一个问题中回答了这一点,但这也可能是对此的答案。我的解决方案基本上是基于将Socket设置为WAMP服务器80端口。

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

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!");
} 

这不会简单得多?

<?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

最新更新