javascript - 计算上传速度

标签 javascript jquery ajax html

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

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 请求)以计算上传速度

最佳答案

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

我宁愿发送原始数据。

这是一个例子:

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”,但它需要更多代码,我看不到这样做有任何改进。

希望对你有帮助

关于javascript - 计算上传速度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21027888/

相关文章:

php - 在 PHP 中加密消息,在 JavaScript 中解密

javascript - 无缝 HTML5 视频循环

javascript - 脚本每次都无法加载

javascript - .click 子div 但不触发单击parent Div?

jquery - 防止直接访问 JSON Web 服务

android - Cordova AJAX 调用仅在发布版本时失败

javascript - Node js console.log 没有显示任何内容

javascript - 检查数组键是否为数字

javascript - 如何使用 ajax.get 调用从 node.js 服务器获取响应

javascript - jquery如何包装每五个元素