【问题标题】:Calculate upload speed计算上传速度
【发布时间】:2021-08-09 12:55:45
【问题描述】:

使用此代码我可以计算我的下载速度:

var imgAddr = "http://upload.wikimedia.org/wikipedia/commons/2/2d/Snake_River_%285mb%29.jpg" + "?n=" + Math.random();
var startTime, endTime;
var download_size = 5*1024*1024;
var img = new Image();
img.onload = function () {
    endTime = (new Date()).getTime();
    ShowData();
}
startTime = (new Date()).getTime();
img.src = imgAddr;

function ShowData()
{
    var duration = (endTime - startTime) / 1000;
    var bitsLoaded = download_size * 8;
    var speedMbps = ((bitsLoaded / duration) / 1024 / 1024).toFixed(2);
    alert("Speed: " + speedMbps + " Mbps");
}

jsfiddle

我如何将相同的图像发送回我的服务器中的虚拟 php(不确定是否需要存在服务器端脚本来“接受”POST 请求)以计算 上传强>速度

【问题讨论】:

  • 你想对图像做什么?为什么要编写脚本来计算下载速度?
  • 为什么?...因为我想向用户展示他的带宽速度。我可以显示下载速度有一定的准确性,现在我想获取上传速度。
  • 如果你把他送到速度测试网站似乎更容易
  • @Huangism:我也在使用来自 speedtest 网站的 API。但我需要知道他们到服务器的速度
  • @Cornwell 你能解释一下你为什么使用 "?n=" + Math.random();在图片网址的末尾?而且我不知道什么是 var download_size = 5*1024*1024;用于?

标签: javascript jquery ajax html


【解决方案1】:

如果您想测试上传速度,我不明白您为什么要发送此特定图片。

我宁愿发送原始数据。

这是一个例子:

var http = new XMLHttpRequest();
var startTime, endTime;
var url = "script_that_whill_handle_post.php";
var myData = "d="; // the raw data you will send
for(var i = 0 ; i < 1022 ; i++) //if you want to send 1 kb (2 + 1022 bytes = 1024b = 1kb). change it the way you want
{
    myData += "k"; // add one byte of data;
}

http.open("POST", url, true);

http.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
http.setRequestHeader("Content-length", myData .length);
http.setRequestHeader("Connection", "close");

http.onreadystatechange = function() {
    if(http.readyState == 4 && http.status == 200) {
        endTime = (new Date()).getTime();
        ShowData();
    }
}
startTime = (new Date()).getTime();
http.send(myData);

(使用相同的showData函数)

您也可以多次发送图像数据而不是字母“k”,但这需要更多代码,我不会看到这样做有任何改进。

希望对你有帮助

【讨论】:

  • 我最终确实这样做了。不幸的是,结果因浏览器而异。尤其是在 IE 中。
  • 考虑增加发送字节的长度。它应该减少差异
  • gzip 传输中的数据怎么样?
  • 如果您使用此脚本进行上传测试...... ShowData() 函数中的变量 download_size 怎么样......?还能用吗?
【解决方案2】:

对于 ajax 上传:

var lastNow = new Date().getTime();
var lastKBytes = 0;
var xhr = new window.XMLHttpRequest();
xhr.upload.addEventListener("progress", function(e) {
    if (e.lengthComputable) {
        var now = new Date().getTime();
        var bytes = e.loaded;
        var total = e.total;
        var percent = bytes / total * 100;
        var kbytes = bytes / 1024;
        var mbytes = kbytes / 1024;
        var uploadedkBytes = kbytes - lastKBytes;
        var elapsed = (now - lastNow) / 1000;
        var kbps =  elapsed ? uploadedkBytes / elapsed : 0 ;
        lastKBytes = kbytes;
        lastNow = now;
        console.log(mbytes.toFixed(2) + "MB (" + percent.toFixed(2) + "%) " + kbps.toFixed(2) + "KB/s");
    }
}, false);

【讨论】:

  • Mb 是兆比特和 nog 兆字节。现在有点混乱,但我验证了它,它应该是:console.log(mbytes.toFixed(2) + "MB (" + percent.toFixed(2) + "%) " + kbps.toFixed(2) + "Kb/s");
猜你喜欢
  • 2011-05-16
  • 1970-01-01
  • 2011-03-09
  • 2021-02-01
  • 1970-01-01
  • 1970-01-01
  • 2011-06-02
  • 1970-01-01
  • 2011-06-27
相关资源
最近更新 更多