如何编写包含两段POST数据的AJAX请求

How to write AJAX request which contains two pieces of POST data?

本文关键字:AJAX 请求 数据 POST 何编写 包含两      更新时间:2023-09-26

所以基本上我试图发送WebGL帧/截图到服务器,这可能会保存这些帧到硬盘驱动器,所以我将能够合并这些保存帧到视频文件。我发现:从webgl导出视频

我不想用WebGL相关的细节来打扰你们…您应该知道的唯一一件事是,我想将两个客户端JavaScript变量的内容发送到localhost node.js服务器。因此,这两个客户端变量如下:

            var frame = frame + 1; //this is the frame counter
            var dataUrl = renderer.domElement.toDataURL("image/png"); //this is the encoded screenshot/frame

接收器服务器端代码由Joe Turner给出(这是在node.js中运行)。所以我的问题是:如何将上述两个变量的内容发送到这个node.js代码?

var http = require('http');
var querystring = require('querystring');
var fs = require('fs');
// Override so we don't decode spaces, and mess up the base64 encoding
querystring.unescape = function(s, decodeSpaces) {
    return s;
};
// Pad to follow the processing export format
function pad(num) {
    var s = "000" + num;
    return s.substr(s.length-4);
}
http.createServer(function (request, response) {
    request.content = '';
    request.addListener("data", function(data) {
        request.content += data;
    });
    request.addListener("end", function() {
        if (request.content.trim()) {
            request.content = querystring.parse(request.content);
            var data = unescape(request.content['data']);
            var frame = request.content['frame'];
            // Remove data:image/png;base64,
            data = data.substr(data.indexOf(',') + 1);
            var buffer = new Buffer(data, 'base64');
            fs.writeFile('screen-' + pad(frame) + '.png',
                         buffer.toString('binary'), 'binary');
        }
    });
    response.writeHead(200, {
        'Content-Type': 'text/plain',
        'Access-Control-Allow-Origin': '*',
        'Access-Control-Allow-Headers': 'X-Requested-With'
    });
    response.end();
}).listen(8080, "127.0.0.1");

我应该这样做吗?

            ...
            ...
            //WebGL related code
            ...
            ...
                            var frame = frame + 1;
                            var dataUrl = renderer.domElement.toDataURL("image/png");
                                $.ajax({
                                    url: "http://127.0.0.1:8080",
                                    type: "POST",
                                    data: {"data": dataUrl, "frame": frame}
                                });
            ...
            ...

例如,让我们看看这个实验:

Three.js基本示例

我在上面的实验中修改了这段代码:

        pointLight.position.copy( camera.position );
        progress += frameTime;
        lastTimestamp = timestamp;
        renderer.render( scene, camera );
        stats.update();
        requestAnimationFrame( animate );

:

        pointLight.position.copy( camera.position );
        progress += frameTime;
        lastTimestamp = timestamp;
        renderer.render( scene, camera );
        stats.update();
        requestAnimationFrame( animate );
        var dataUrl = "";
        var frame = 10;
        $.ajax({
                url: "http://127.0.0.1:8080",
                type: "POST",
                data: {"data": dataUrl, "frame": frame}    
        });

但是仍然看不到任何已保存的图像文件

您编写的代码只需要在其url中具有正确的协议(您缺少"http://"):

var frame = frame + 1;
var dataUrl = renderer.domElement.toDataURL("image/png");
$.ajax({
        url: "http://127.0.0.1:8080",
        type: "POST",
        data: {"data": dataUrl, "frame": frame}    
});

从您发布的代码中,您可以看到服务器已经在解析请求并提取您在POST

中发送的两个参数
if (request.content.trim()) {    
    request.content = querystring.parse(request.content);
    var data = request.content['data'];
    var frame = request.content['frame'];
    //...

$中添加到POST请求中的任何内容。调用

时可以通过名称检索Ajax
request.content['name']

只要确保您在客户端和服务器代码中使用的名称匹配即可。

另外,node.js代码正在接收一个转义的base64字符串,这不能使此函数工作

data.substr(data.indexOf(',') + 1);

因为','字符被转义了。

要解决这个问题,只需在数据字符串上使用节点内置函数unescape,如下所示
var data = unescape(request.content['data']);