Php 在从mysql数据库(Android)中提取数据之前,请确保wamp服务器处于联机状态
在从mysql数据库获取数据之前,我需要确保wamp服务器在线,如果没有,应用程序会告诉用户在提取数据之前先将其在线,这在android中如何实现?好像是离线的android应用程序停止了 连接到数据库的PHP代码是: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-&
<?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服务器将处于联机状态。。