我有一个活动负责Pinging 254 IPv4并在点击按钮“自动扫描”时将连接的机器放入数据库表(放入ip)。 // ------------------------------------------------ ---------------------
首先我得到本地IP(例如192.168.1.8),然后当点击按钮时,我从ip中提取一个子串(对于这个例子为192.168.1。)然后从“192.168”开始ping所有IP。 1.1“并以”192.168.1.254“完成。每次ping之后,我都会做一个测试,知道ping是成功还是失败,如果成功,那么我把那个ip放在数据库表中,然后最后我在列表视图中显示连接的IP列表。 // ------------------------------------------------ ---------------------
问题是Pinging任务花了太长时间才完成(大约15分钟或更长时间!!),这很疯狂。 我试图使用InetAddress.isReachable()它很快,但它找不到使用Windows的计算机,所以我改为使用Process&调用Runtime.getRuntime()。EXEC(CMD)。
在Android代码下方:
class MyTask extends AsyncTask<String, Integer, Void> {
Dialog dialog;
ProgressBar progressBar;
TextView tvLoading,tvPer;
Button btnCancel;
@Override
protected Void doInBackground(String... params) {
Thread.currentThread().setPriority(Thread.MAX_PRIORITY);
String s="", address = params[0];
int index=0,j=0,count=0;
//on prend le dernier index du char "."
final StringBuilder ss = new StringBuilder(address);
index = ss.lastIndexOf(".");
//on prend une souschaîne qui contient l'ipv4 sans le dernier nombre
s = address.substring(0,index+1);
//Tester tous les adresses Ipv4 du même plage d'adresses
for(int i=1; i<255; i++){
if (isCancelled()) {
break;
}
if(testping(s+""+i+"")){
insertIPv4(s+""+i+"");}
count++;
if(count == 5 && j<100){
count=0;
j+=2;
publishProgress(j);
}
}
return null;
}
@Override
protected void onPostExecute(Void result){
super.onPostExecute(result);
dialog.dismiss();
AlertDialog alert = new AlertDialog.Builder(Gestion_Machines.this)
.create();
alert.setTitle("Terminé");
alert.setMessage("Operation Terminé avec Succés");
alert.setButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
alert.show();
}
@Override
protected void onPreExecute() {
super.onPreExecute();
dialog = new Dialog(Gestion_Machines.this);
dialog.setCancelable(false);
dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
dialog.setContentView(R.layout.progressdialog);
progressBar = (ProgressBar) dialog.findViewById(R.id.progressBar1);
tvLoading = (TextView) dialog.findViewById(R.id.tv1);
tvPer = (TextView) dialog.findViewById(R.id.tvper);
btnCancel = (Button) dialog.findViewById(R.id.btncancel);
btnCancel.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
objMyTask.cancel(true);
dialog.dismiss();
}
});
dialog.show();
}
@Override
protected void onProgressUpdate(Integer... values) {
super.onProgressUpdate(values);
progressBar.setProgress(values[0]);
tvLoading.setText("Loading... " + values[0] + " %");
tvPer.setText(values[0]+" %");
}
}
和制作ping的方法:
public boolean testping(String x){
int exit=22;
Process p;
try {
//.....edited line.....
p = Runtime.getRuntime().exec("ping -c1 -W1 "+x);
//make shure that is -W not -w it's not he same.
p.waitFor();
exit = p.exitValue();
p.destroy();
} catch (IOException ee) {
ee.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
if (exit == 0) {
return true;
}else{
return false;
}
}
答案 0 :(得分:1)
我在网上搜索,我发现在java中,有些人使用了一个名为&#34; fping&#34;接受超时选项(-t)和毫秒。但android(shell)中的ping命令只能接受秒的超时。所以,对于我的情况,洞操作应该花费254秒,不错......但不完美。
public boolean testping(String x){
int exit=22;
Process p;
try {
//.....edited line.....
p = Runtime.getRuntime().exec("ping -c1 -W1 "+x);
//make shure that is -W not -w it's not he same.
p.waitFor();
exit = p.exitValue();
p.destroy();
} catch (IOException ee) {
ee.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
if (exit == 0) {
return true;
}else{
return false;
}
}