javascript - FormData 从 multipart/form-data 更改为 form-urlencoded?

标签 javascript node.js ajax multipartform-data form-data

我正在使用当前的 javascript 来发布表单数据

var request = new XMLHttpRequest();
request.open("POST", "/validate",false);
request.send(new FormData(form));  // form is document.getElementById("#form")

使用 expressjs 后端,使用 body-parser 并进行以下设置

app.use(parser.urlencoded({ extended: false }));

表单数据已使用 content-type 正确发布到 multipart/form-data; 但根据 body-parser他们不解析多部分内容。如何将表单提交更改为 urlencodedjson 两者都可以由后端解析?

最佳答案

尝试添加 header 来请求并将数据转换为 url-encode 格式

function urlencodeFormData(fd){
    var s = '';
    function encode(s){ return encodeURIComponent(s).replace(/%20/g,'+'); }
    for(var pair of fd.entries()){
        if(typeof pair[1]=='string'){
            s += (s?'&':'') + encode(pair[0])+'='+encode(pair[1]);
        }
    }
    return s;
}
var request = new XMLHttpRequest();
request.open('POST', '/validate', false);
request.setRequestHeader('Content-Type','application/x-www-form-urlencoded')
request.send(urlencodeFormData(new FormData(form)));

关于javascript - FormData 从 multipart/form-data 更改为 form-urlencoded?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45812318/

相关文章:

javascript - AngularJS 和 UI 路由器 : 'Error: transition superseded' during angularjs unit tests

javascript - 在 https 上运行安全 Web 套接字需要什么?

javascript - Node JS Inspect 显示属性具有值,但检查属性返回未定义

node.js - 在 headless 模式下使用来自 Chromium 的 cookie

c# - Ajax 重新排序列表不可拖动

jQuery ajax 登录表单与 asp.net mvc

javascript - 我正在尝试将数据从单元格范围发送到不和谐的聊天 channel

javascript - 无法在 jquery 自动完成中获取文本框的值

node.js - 如何通过apache连接 Node 服务器?

javascript - 获取子数据 Microsoft Dynamics WebAPI