开发者

Multiple post requests and small web server

开发者 https://www.devze.com 2023-04-06 15:08 出处:网络
I have a problem with a small web server with limited resources: The device is an embedded controller with network interface and uses web pages for configuration.

I have a problem with a small web server with limited resources:

  • The device is an embedded controller with network interface and uses web pages for configuration.

  • The data are exchanged with json format and the post method.

The problem is this: my device can serve only one post request at a time with a small buffer size.

To test it, I created a page with multiple posts for sending data to my server. I opened the page with the browser Firefox 4.0 and the browser tried to open multiple socket to serve all requests in parallel.

How do I create a sequential flow message? (I'm not worried about the speed)

Here is a small example of how I intend to proceed, but this solution opens two sockets for sending two post requests to my server and aborts one of them.

for (var j=0; j<2; j++) {
    // read page data and create objdata  
 开发者_开发百科   jdata = JSON.stringify(objdata);

    // alert("I am about to POST this:\n\n" + jdata);

   $.post(
     'prgtimetbl.json',
     jdata,
     function(data) {
     //           alert("Response: " + data);
     },
     "json"
   );
}


With jQuery use $.ajax and async: false:

$.ajax({
    type: "POST",
    url: "some.php",
    async: false,
    data: "name=John&location=Boston",
    success: function(msg){
        alert( "Data Saved: " + msg );
    }
});


Cixate was faster than me, but I had a slightly different approach using async queued requests.

Sample: http://jsfiddle.net/HTGPM/

Code:

$(document).ready(function(){
    var stuffToPost = [{name:'obj1',id:1},{name:'obj2',id:2},{name:'obj3',id:3}];
    var postIndex = 0;

    var postNext = function() {
        if (postIndex < stuffToPost.length)
        {
            $.ajax({
                type: 'post',
                url: '?',
                data: JSON.stringify(stuffToPost[postIndex]),
                success: function(data) {
                    alert('Data '+stuffToPost[postIndex].id+' was sent successfully');
                    postIndex++;
                    postNext();
                },
                error: function() {
                    alert('Something bad happened. Stopping');
                }
            });
        }
        else if (postIndex == stuffToPost.length)
        {
            alert('All data is sent !');
        }
    };

    postNext();
});
0

精彩评论

暂无评论...
验证码 换一张
取 消