Javascript PING

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>HTTP Ping</title>
<style>
html
{
	height: 100%;
	overflow: hidden;
}

body
{
	background: #000;
	color: #C0C0C0;
	font-weight: bold;
	font-size: 14px;
	font-family: Lucida Console;
	height: 100%;
	margin: 0 0 0 5px;
}

#divInput
{
	height: 10%;
}

#divContent
{
	height: 90%;
	overflow: auto;
}

#txtTimeout
{
	width: 40px;
}

button
{
	margin-left: 10px;
}
</style>
</head>

<body>

<div id="divInput">
	<span>URL:</span>
	<input id="txtURL" type="text" />
	<span>Timeout:</span>
	<input id="txtTimeout" type="text" value="2000" />
	<input id="btnSwitch" type="button" value="Start" οnclick="handleBtnClick()" />
	<hr/>
</div>
<div id="divContent"></div>

<script>
var intStartTime;
var objIMG = new Image();


objIMG.onload =
objIMG.onerror = 
function()
{
	/*
	 * 有回应,取消超时计时
	 */
	clearTimeout(intTimerID);

	if(!bolIsRunning || bolIsTimeout)
		return;

	var delay = new Date() - intStartTime;

	println("Reply from " +
			strURL +
			" time" +
			((delay<1)?("<1"):("="+delay)) +
			"ms");
	arrDelays.push(delay);

	/*
	 * 每次请求间隔限制在1秒以上
	 */
	setTimeout(ping, delay<1000?(1000-delay):1000);
}

function ping()
{
	/*
	 * 发送请求
	 */
	intStartTime = +new Date();
	intSent++;

	objIMG.src = strURL + "/" + intStartTime;
	bolIsTimeout = false;

	/*
	 * 超时计时
	 */
	intTimerID = setTimeout(timeout, intTimeout);
}

function timeout()
{
	if(!bolIsRunning)
		return;

	bolIsTimeout = true;
	objIMG.src = "X:\\";

	println("Request timed out.");
	ping();
}
</script>


<script>
var $ = function(v){return document.getElementById(v)};

var arrDelays = [];
var intSent;

var bolIsRunning = false;
var bolIsTimeout;
var strURL;
var intTimeout;
var intTimerID;

var objBtn = $("btnSwitch");
var objContent = $("divContent");
var objTxtURL = $("txtURL");

objTxtURL.value = window.location.host;

function handleBtnClick()
{
	if(bolIsRunning)
	{
		/*
		 * 停止
		 */
		var intRecv = arrDelays.length;
		var intLost = intSent-intRecv;
		var sum = 0;

		for(var i=0; i<intRecv; i++)
			sum += arrDelays[i];

		objBtn.value = "Start";
		bolIsRunning = false;

		/*
		 * 统计结果
		 */
		println(" ");
		println("Ping statistics for " + strURL + ":");
		println("  Packets: Sent = " +
				intSent +
				", Received = " +
				intRecv +
				", Lost = " +
				intLost +
				" (" +
				Math.floor(intLost / intSent * 100) +
				"% loss),");

		if(intRecv == 0)
			return;

		println("Approximate round trip times in milli-seconds:");
		println("  Minimum = " +
				Math.min.apply(this, arrDelays) +
				"ms, Maximum = " +
				Math.max.apply(this, arrDelays) +
				"ms, Average = " +
				Math.floor(sum/intRecv) +
				"ms");
	}
	else
	{
		/*
		 * 开始
		 */
		strURL = objTxtURL.value;

		if(strURL.length == 0)
			return;

		if(strURL.substring(0,7).toLowerCase() != "http://")
			strURL = "http://" + strURL;

		intTimeout = parseInt($("txtTimeout").value, 10);
		if(isNaN(intTimeout))
			intTimeout = 2000;
		if(intTimeout < 1000)
			intTimeout = 1000;

		objBtn.value = "Stop ";
		bolIsRunning = true;

		arrDelays = [];
		intSent = 0;

		cls();
		println("Pinging " + strURL + ":");
		println(" ");
		ping();
	}
}

function println(str)
{
	var objDIV = document.createElement("div");

	if(objDIV.innerText != null)
		objDIV.innerText = str;
	else
		objDIV.textContent = str;

	objContent.appendChild(objDIV);
	objContent.scrollTop = objContent.scrollHeight;
}

function cls()
{
	objContent.innerHTML = "";
}
</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值