Node.js / Express DELETE方法不起作用

时间:2017-06-02 15:27:22

标签: javascript node.js

我试图删除表单的数据。 GET和PUT方法有效但不是DELETE。我的目标是使用JS函数更改表单POST方法,然后使用删除按钮调用它,这样我就可以删除数据。但它不起作用。 HTML:

<form id="protest_form" action="scout_post" method="POST">

            <input type="text" id="scoutName" name="scoutName" placeholder="name"> <br>
            <input type="text" id="scoutSurname" name="scoutSurname" placeholder="surname"> <br>
            <input type="text" id="scoutPassword" name="scoutPassword" placeholder="password"> <br>

            <button type="submit" id="button" class="btn btn-primary">Submit</button>
            <button type="button" id="button" class="btn btn-danger" onclick="deleteForm()">Delete</button>
        </form>

JS功能:

function deleteForm() {

        document.getElementById('protest_form').setAttribute("method", "delete");
        document.getElementById('protest_form').submit();

    }

节点路线:

app.post('/scout_post', urlencodedParser,function (req,res){

    var name= req.body.scoutName,
        surname=req.body.scoutSurname,
        password=req.body.scoutPassword;


            db.collection('scoutPost').insertOne(
                { 'name': name, 'surname': surname,'password':password},
                function (err, r) {
                    assert.equal(null, err);
                    res.send("Document inserted with _id: " + r.insertedId);
                }
            );  
})

app.delete('/scout_post', urlencodedParser,function (req,res){

        var name= req.body.scoutName,
            surname=req.body.scoutSurname,
            password=req.body.scoutPassword;


                db.collection('scoutPost').remove(
                    { 'name': name, 'surname': surname,'password':password},
                    function (err, r) {
                        assert.equal(null, err);
                        res.send("Document deleted");

                    });

    }) 

当我点击调用deleteForm()函数的按钮时,我收到此错误:

Cannot GET /scout_post?scoutName=&scoutSurname=&scoutPassword=

如果我将HTML和Node路由更改为GET方法,我会插入文档,而不是在单击DEL按钮时删除...如何解决此问题?感谢

2 个答案:

答案 0 :(得分:1)

HTML表单中只允许GET和POST。如果要提交DELETE请求,则必须通过XHR客户端在服务器端使用a method override middleware并在客户端进行适当的更改。< / p>

答案 1 :(得分:0)

正如MDN上的文档所说,表单方法属性上只有“POST”和“GET”方法可用。你需要使用AJAX来完成这个