gpt4 book ai didi

javascript - 如何编写包含两条POST数据的AJAX请求?

转载 作者:行者123 更新时间:2023-12-03 09:35:53 24 4
gpt4 key购买 nike

所以基本上我正在尝试将 WebGL 帧/屏幕截图发送到服务器,该服务器可能会将这些帧保存到硬盘驱动器,以便我能够将这些保存的帧合并到视频文件中。我发现了这个: Exporting video from webgl

我不想用 WebGL 相关的细节来打扰你们...你们唯一应该知道的是,我想将两个客户端 JavaScript 变量的内容发送到本地主机 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 basic example

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

        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}
});

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

最佳答案

您编写的代码只需要在其网址中包含正确的协议(protocol)(您缺少“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'];
//...

在 $.ajax 中添加到 POST 请求的任何内容都可以在调用时按名称检索

request.content['name']

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

此外,node.js 代码正在接收转义的 Base64 字符串,这不会使该函数工作

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

由于“,”字符被转义。

要解决这个问题,只需在数据字符串上使用节点内置函数unescape,如下所示

var data = unescape(request.content['data']);

关于javascript - 如何编写包含两条POST数据的AJAX请求?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31339452/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com