import java.net.InetAddress
import java.util.ArrayList
import java.util.GregorianCalendar
import java.util.List
import jpcap.JpcapCaptor
import jpcap.JpcapSender
import jpcap.NetworkInterface
import jpcap.packet.EthernetPacket
import jpcap.packet.ICMPPacket
import jpcap.packet.IPPacket
public class JPing {
private NetworkInterface[] devices = JpcapCaptor.getDeviceList()
private JpcapSender sender
private JpcapCaptor jpcap
private ICMPPacket icmpPacket
private List<String>listResult = new ArrayList<String>()
/**
* 组织ICMP报文发送,并开启线程接收纯塌报文
* @param ip
*/
public void ping(String ip) {
try {
jpcap = JpcapCaptor.openDevice(devices[0], 200, false, 20)
sender = jpcap.getJpcapSenderInstance()
jpcap.setFilter("icmp", true)// 过滤器,只接受ICMP报文
icmpPacket = new ICMPPacket()
icmpPacket.type = ICMPPacket.ICMP_ECHO// 发送回显请求报文
icmpPacket.setIPv4Parameter(0, false, false, false, 0, false,
false, false, 0, 1010101, 100, IPPacket.IPPROTO_ICMP,
devices[0].addresses[1].address, InetAddress.getByName(ip))
// 随意的32bytes数据
icmpPacket.data = "abcdefghijklmnopqrstuvwxyzabcdef".getBytes()
EthernetPacket ethernetPacket = new EthernetPacket()
ethernetPacket.frametype = EthernetPacket.ETHERTYPE_IP
ethernetPacket.src_mac = devices[0].mac_address
// 广播地址
ethernetPacket.dst_mac = new byte[] { (byte) 0xff, (byte) 0xff,
(byte) 0xff, (byte) 0xff, (byte) 0xff, (byte) 0xff }
icmpPacket.datalink = ethernetPacket
listResult.add("Pinging " + icmpPacket.dst_ip + " with "
+ icmpPacket.data.length + " bytes of data: ")
startCapThread(jpcap)
for (int i = 0i <5i++) {
icmpPacket.sec = 0
//icmpPacket.usec = System.currentTimeMillis()
icmpPacket.usec = new GregorianCalendar().getTimeInMillis()// 记录发送时做森圆间
icmpPacket.seq = (short) (1000 + i)
icmpPacket.id = (short) (999 + i)
sender.sendPacket(icmpPacket)
try {
Thread.sleep(1000)
} catch (Exception e) {
e.printStackTrace()
}
}
} catch (Exception e) {
e.printStackTrace()
}
}
/**
* 接收ICMP报文
* @param jpcap
*/
public void getIcmpPacket(JpcapCaptor jpcapCaptor) {
try {
while (true) {
long tmp = 0
String tmpStr = null
ICMPPacket rp
rp = (ICMPPacket) jpcapCaptor.getPacket()
if ((rp != null) &&(rp.seq - rp.id == 1)
&&(rp.type == ICMPPacket.ICMP_ECHOREPLY)) {// 若是ICMP回应报文,则列出。。。
tmp = (rp.sec * 1000 + rp.usec / 1000 - icmpPacket.sec
* 1000 - icmpPacket.usec)// 计算发送与接受的时间差
if (tmp <= 0)
tmpStr = " <1 ms "
else
tmpStr = "= " + tmp + " ms "
System.out.println("Reply from "
+ rp.src_ip.getHostAddress() + ": bytes = "
+ rp.data.length + " time " + tmpStr + "TTL = "
+ rp.hop_limit)
listResult.add("Reply from " + rp.src_ip.getHostAddress()
+ ": bytes = " + rp.data.length + " time " + tmpStr
+ "TTL = " + rp.hop_limit)
}
}
} catch (Exception e) {
e.printStackTrace()
}
}
/**
* 接收ICMP报文
* @param jpcap
*/
public void startCapThread(final JpcapCaptor jpcap) {
Runnable runner = new Runnable() {
public void run() {
getIcmpPacket(jpcap)
}
}
new Thread(runner).start()
}
public static void main(String[] args) {
new JPing().ping("www.baidu.com")
}
}
给你介绍Java实现ping功能的三种方法:
检测设备的运行状态,有的是使用ping的方磨升式来检测的。所以需要使用java来实现ping功能。
1.Jdk1.5的InetAddresss方式
自从Java 1.5,java.net包中就实现了ICMP ping的功能。
使用时应注意,如果远程服务器设置了防火墙或相关的配制,可能会影响到结果。带明另外,由于发送ICMP请求需要程序对系统有一定的权限,当这个权限无法满足时, isReachable方法将试着连接远程主机的TCP端口 7(Echo)。
2.最简单的办法,直接调用CMD 见Ping类的ping02(String)函数。
3.Java调用控制台执行ping命令
具体的思路是这样的:
通过程序调用类似“ping 127.0.0.1 -n 10 -w 4”的命令,这命令会执行ping十次,如果通顺则会输出类似“来自127.0.0.1的回复: 字节=32 时间<1ms TTL=64”的文本(具体数字根据实际情况会有变化),其中中文是根据环境本地化的,有些机器上的中文部分是英文,但不论是中英文环境, 后面的“<1ms TTL=62”字样总是固定的,它表明一次ping的结果是能通的。如果这个蠢游告字样出现的次数等于10次即测试的次数,则说明127.0.0.1是百分之百能连通的。
技术上:具体调用dos命令用Runtime.getRuntime().exec实现,查看字符串是否符合格式用正则表达式实现。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)