<!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" onclick="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>
分享到:
相关推荐
PingyJS 是一个用于在 JavaScript 中 ping 网站的小型库。 例子 pingy . ping ( "http://google.com" , function ( success ) { if ( success ) { alert ( "Google.com is UP!" ) ; } else { alert &...
主要介绍了纯Javascript实现ping功能的方法,实例分析了javascript实现ping功能的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
但是,对于 3 的倍数,页面会打印“ping”而不是数字,对于 5 的倍数,页面会打印“pong”。对于 3 和 5 的倍数的数字,页面会打印'乒乓'。” - 看到它在行动克隆存储库: $ git clone ...
js模拟ping命令!js模拟ping命令!j
JS虽然不能真正发送Ping的ICMP数据包,在请求时无法统计HTTP头部的长度,所以当请求数据包长度在最大传输单元临界点时,额外的HTTP头可以导致IP分组,因此存在一定的误差,但Ping的本质仍然是请求/回复的时间差,HTTP...
Ping Pong Game using JavaScript with Source Code
JS虽然发送不了真正Ping的ICMP数据包,但Ping的本质仍然是请求/回复的时间差,HTTP自然可以实现此功能.
Ping-Pong是用JavaScript编写的无依赖项的伪ping实用程序,可让您轻松确定某个HTTP服务器是否在线。 有时,在发出AJAX请求之前,您需要知道服务器是否处于活动状态。 或者,也许您像Apollo Music中的我们一样,您...
Ping.js是一个小巧的Javascript库,供浏览器“ ping”对Javascript中的Web服务器的响应时间! 当您要在状态页面上显示相对于用户的实时ping时间时,这很有用。 有关其工作原理,请参见下面的。 JS小提琴示例: :...
Ping-game-javascript
安装将 pingService.js 复制到项目的 JavaScript 目录。 将“pingService”模块的依赖项添加到您的应用程序。 将“ping”服务注入您的控制器。用法从您的控制器: ping.ping(testURL, function(response) { if ...
获取用户输入的数字,并使用javascript / jquery在页面上插入数字。 对于被3整除的数字,它打印“ ping”;对于被5整除的数字,它打印“ pong”;对于被15整除的数字,它打印“ ping-pong”。 15年10月27日更新-...
Node.js的ping包装器 @ last-modified:2020-12-26 许可麻省理工学院 (C)丹尼尔·泽利斯科 描述 节点ping是系统ping实用程序的简单包装 安装 npm安装ping 用法 以下是从examples摘录的examples 传统电话 var ping...
该模块实现了对ICMP Echo (ping) 支持。 此模块使用: npm install net-ping 它使用require()函数加载: var ping = require ("net-ping"); 然后可以创建一个 ping 会话来 ping 或跟踪到许多主机的路由: var...
Ping 监视器 一个简单的工具,用于监控用 Go 和 Web 技术编写的服务器 ping。 它是如何工作的? 它每分钟为每个目标(IP 或服务器)在 Redis 存储中存储 ping 时间。 为了提高准确性,它每 20 秒 ping 每个目标并...
npm install ping-tcp-js ping 参数 const host = 'google.com'; const port = 80; client.ping(host, port); // or client.ping({host, port}); 主持人 const client = require('ping-tcp-js'); const host = ...
该存储库包含用于构建以Javascript实现的Databus Ping Pong应用程序示例的源文件。 请参阅以获取有关此应用程序示例的更多信息。 概述 node:10.16.3-alpine Ping Pong应用程序示例的此实现使用node:10.16.3-alpine...
npm install -g dat-ping dat-ping <location> [--bin=path/to/dat/executable] HTTP,SSH,文件系统等 $ dat-ping http://localhost:6443 $ dat-ping ~/dev/dats/eukaryota.dathub.org/ 退货 {"transaction":false...