您的位置:

js模拟ping程序(计算机网络ping程序实现)

js模拟ping程序(计算机网络ping程序实现)

更新:

本文目录一览:

使用jquery插件测试url链接是否有效及js ping url

要用的需要明白代码及自己改些地方

(function($) {

$.fn.ping = function(options) {

var opts = $.extend({}, $.fn.ping.defaults, options);

var stime = new Date().getTime();

return this.each(function() {

var ping, requestTime, responseTime ;

var target = $(this);

function ping(){

node.js怎么调用ping

let ping = require('child_process').spawn('ping',['127.0.0.1']);

let iconv = require('iconv-lite');

ping.stdout.on('data',data={

    let str = iconv.decode(data,'cp936');

    console.log(str);

})

ping.stderr.on('data',data={

    console.log(data);

})

ping.on('close',code={

    console.log('Ping 结束')

})

//之前是通过exec 来调用,不过当时没有进行测试,想当然的认为是可以的,抱歉。

//以上引入iconv-lite 是为了解码中文

求一段JS代码,如果本域名主机下“/web/111.html”网页存在,则alert("YES"),否则alert("NO")

使用jQuery模拟PING:

$.ping = function(option) {    var ping, requestTime, responseTime ;    var getUrl = function(url){    //保证url带http://        var strReg="^((https|http)?://){1}"        var re=new RegExp(strReg);         return re.test(url)?url:"http://"+url;    }    $.ajax({        url: getUrl(option.url)+'/'+ (new Date()).getTime() + '.html',  //设置一个空的ajax请求        type: 'GET',        dataType: 'html',        timeout: 10000,        beforeSend : function()         {            if(option.beforePing) option.beforePing();            requestTime = new Date().getTime();        },        complete : function()         {            responseTime = new Date().getTime();            ping = Math.abs(requestTime - responseTime);            if(option.afterPing) option.afterPing(ping);        }    });     if(option.interval  option.interval  0)    {        var interval = option.interval * 1000;        setTimeout(function(){$.ping(option)}, interval);//        option.interval = 0;        // 阻止多重循环//        setInterval(function(){$.ping(option)}, interval);    }};    

//栗子 HTML

div id="msg"/div

$.ping({

    url : '',

    beforePing : function(){$('#msg').html('')},

    afterPing : function(ping){$('#msg').html(ping)},

    interval : 1

});

能否使用JavaScript来ping一个IP?

可以在javascript中ping一个ip地址:

以下是自定义的实现函数:

function Pinger_ping(ip, callback) {

if(!this.inUse) {

this.inUse = true;

this.callback = callback

this.ip = ip;

var _that = this;

this.img = new Image();

this.img.onload = function() {_that.good();};

this.img.onerror = function() {_that.good();};

this.start = new Date().getTime();

this.img.src = "http://" + ip;

this.timer = setTimeout(function() { _that.bad();}, 1500);

}

}

用法如下:

传入ip和callback参数:比如192.0.8.10 和 mycallBack

setTimeout的返回值就可以判断了。

js检测网站是否能打开

找到一个ping的代码

!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ""

html xmlns=""

head

meta http-equiv="Content-Type" content="text/html; charset=gb2312" /

titleHTTP 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" spanURL:/span

    input id="txtURL" type="text" /

    spanTimeout:/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" +   

            ((delay1)?("1"):("="+delay)) +   

            "ms");   

    arrDelays.push(delay);   

  

    /*   

     * 每次请求间隔限制在1秒以上   

     */   

    setTimeout(ping, delay1000?(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; iintRecv; 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

js模拟ping程序(计算机网络ping程序实现)

本文目录一览: 1、使用jquery插件测试url链接是否有效及js ping url 2、node.js怎么调用ping 3、求一段JS代码,如果本域名主机下“/web/111.html”网页存在,

2023-12-08
js写ping代码(ping 语法)

本文目录一览: 1、node.js怎么调用ping 2、能否使用JavaScript来ping一个IP? 3、求一段JS代码,如果本域名主机下“/web/111.html”网页存在,则alert("Y

2023-12-08
虚拟机nat模式ping不通主机的原因和解决方法

2023-05-21
如何使两个虚拟机ping通

2023-05-23
华为ensp模拟器:一步一步实现网络拓扑配置

2023-05-21
Ping协议详解

2023-05-23
js高级程序设计笔记14(js高级程序设计笔记14页)

本文目录一览: 1、JavaScript高级程序设计 该怎么看 2、JavaScript学习笔记之数组基本操作示例 3、JS中有关sort以及return的问题 JavaScript高级程序设计 该怎

2023-12-08
jsp程序开发学习笔记2,jsp程序设计题库

本文目录一览: 1、《JSP&Servlet学习笔记》pdf下载在线阅读,求百度网盘云资源 2、林信良编著jsp&servlet学习笔记第2版课后答案吗 3、jsp有没有快速掌握的办法呀? 4、要学J

2023-12-08
虚拟机没网络怎么办

2023-05-22
udpping工具:网络Ping测试神器

2023-05-19
C# Ping详解

2023-05-23
Linux命令实战:使用ping模块检测网络连通性

2023-05-13
Ping在线:打造稳定高效的网络测速工具

2023-05-20
详解Windows ping ipv6

2023-05-22
解决VMware虚拟机桥接模式无网络连接问题

2023-05-22
详解Ping百度

2023-05-20
使用Linux ping命令检测网络连接状况

2023-05-13
vmware桥接模式ping不通主机原因与解决方法

2023-05-18
js网页程序设计(网页设计程序语言)

本文目录一览: 1、用JS设计一个页面,在页面上显示信息"现在是XXXX年XX月XX日XX点XX分XX秒(星期X),欢迎您到访我的站点". 2、网页编程,如何用js创建一个按钮 3、javascrip

2023-12-08
MAC如何进行PING地址操作

2023-05-17