js检测网址是否可访问,javascript检测网址是否可访问,支持跨域;

js检测网址是否可访问,javascript检测网址是否可访问,支持跨域;

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>url检测是否可访问</title>
    <style>
    </style>
</head>
<body>
    <div id="km" style="font-size:23px;"></div>
    <script type="text/javascript">

        function getTimeDiff(startTime, endTime) {
            //var start = Date.parse(startTime);
            //var end = Date.parse(endTime);

            //var diff = Math.abs(end - start); // 返回时间差的毫秒数
            var diff = Math.abs(endTime - startTime); // 返回时间差的毫秒数
            return diff;
            //var seconds = Math.floor(diff / 1000);
            //var minutes = Math.floor(seconds / 60);
            //var hours = Math.floor(minutes / 60);
            //var days = Math.floor(hours / 24);

            // return days + "天 " + (hours % 24) + "小时 " + (minutes % 60) + "分钟 " + (seconds % 60) + "秒";
        }
 
        function importScript(sSrc, fOnload) {
            document.getElementById("km").innerHTML += "<br/>" + sSrc + "检测中....<br/>";
            var isConnected = false;
            var oScript = document.createElement("script");
            oScript.type = "text/javascript";
            var startTime = new Date();
            oScript.onerror = function (r) {
                var millisecond = getTimeDiff(startTime, new Date());
                console.log("连接出错-------------- " + sSrc);
                console.log(444, r);
                document.getElementById("km").innerHTML += "<br/>" + sSrc + "连接出错,耗时" + millisecond + "毫秒<br/>";
            };
            //if (fOnload) {
            //    oScript.onload = fOnload;
            //}
            oScript.onload = function (r) {
                var millisecond = getTimeDiff(startTime, new Date());
                isConnected = true;
                console.log("连接成功-------------- " + sSrc);
                console.log(555, r);
                document.getElementById("km").innerHTML += "<br/>" + sSrc + "连接成功,耗时" + millisecond + "毫秒<br/>";
            };
            document.currentScript.parentNode.insertBefore(
                oScript,
                document.currentScript,
            );
            oScript.src = sSrc;
            setTimeout(function () {
                //连接超时,触发
                if (!isConnected) {
                    console.log("连接超时-------------- " + sSrc);
                    var millisecond = getTimeDiff(startTime, new Date());
                    document.getElementById("km").innerHTML += "<br/>" + sSrc + "连接出错,超时,耗时" + millisecond + "毫秒<br/>";
                    //oScript.remove();
                    //window.location.href = "http://www.baidu.com";
                }
            }, 800);
        }
         
        !function () {          
            importScript("http://km.gg.com.cn:10081", function () { });
            importScript("http://km.bb.com.cn", function () { });
        }();
    </script>
</body>
</html>
相关推荐
我是一颗柠檬几秒前
【JDK8新特性】方法引用与构造器引用Day3
java·开发语言·后端·intellij-idea
子榆.1 分钟前
CANN自定义GEMM算子(Ascend C手写高性能矩阵乘法)
c语言·开发语言·矩阵
迁旭9 分钟前
Claude Code /status 功能技术文档
前端·javascript·人工智能·react.js·机器学习·gpt-3·文心一言
星星~笑笑12 分钟前
react Next.js oss上传 上传阿里云
javascript·react.js·阿里云·js
LB211213 分钟前
C++通讯录课设(西安石油大学)
开发语言·c++·算法
专注VB编程开发20年1 小时前
python语法设计、IDE 生态、平台策略、解析器逻辑这四层的矛盾点
开发语言·ide·python
潜创微科技9 小时前
IT6520:USB‑C 转 MIPI 芯片方案 4K@120Hz 高清显示
c语言·开发语言
言之。10 小时前
【Python】免费的中文 AI 配音方案
开发语言·人工智能·python
天天进步201510 小时前
Python全栈项目:从零手操一个高性能 API 网关
开发语言·python
Java面试题总结10 小时前
java高频面试题(2026最新)
java·开发语言·jvm·数据库·spring·缓存