0

我正在尝试将一些 json 数据发布到使用 Jersey 框架实现的 REST Web 服务。我没有使用 JAXB 或 jquery,而只使用 javascript。
我验证了形成的 json 是正确的,但尽管设置了内容类型“application/json”,但在服务器上它被接收为“application/x-www-form-urlencoded”。
这是我的代码:

<html>
<head>
<script type="text/javascript">
    function DisplayFormValues()
    {
        var str = {};
        var elem = document.getElementById('frmMain').elements;

        //alert(elem.length);
        for(var i = 0; i < elem.length-1; i++)
        {
            str[elem[i].name] = elem[i].value;

        }
        document.getElementById('lblValues').innerHTML = str;

        var json = JSON.stringify(str);

        // construct an HTTP request
        var xhr = new XMLHttpRequest();
        xhr.open(document.getElementById('frmMain').method,
                document.getElementById('frmMain').action);
        xhr.setRequestHeader("Content-type", "application/json");
        xhr.setRequestHeader("Content-Length",json.length);
        xhr.setRequestHeader('Accept', 'application/json');


        //alert(json);
        // send the collected data as JSON
        xhr.send(json);


        xhr.onloadend = function() {
            // done
        }
    }
</script>
</head>
<body>
    <form id="frmMain" name="frmMain" action="/JerseyTest/rest/postUser"
        method="post">

        <input name="firstName" value="harry" /> <input name="lastName"
            value="tester" /> <input name="toEmail" value="testtest@test.com" />
        <br /> <input type="submit" value="Test"
            onclick="DisplayFormValues();" />
    </form>
    <hr />
    <div id="lblValues"></div>
</body>
</html>  

在服务器端:

package com.example.jersey.test;


import javax.ws.rs.*;

@Path("/postUser")
public class JsonTest {

    @POST
    @Consumes("application/json")
    @Produces(MediaType.TEXT_PLAIN)
    public String pingPong(String json) {

        return "Answer is "+ json;
    }
}  

我是 Web 开发的新手,不确定上面的代码中缺少什么。

4

1 回答 1

0

我正在为以后可能会访问此内容的人回答我自己的问题。上面的代码是正确的并且运行良好,除了 url 被点击了两次。第一次,提交按钮的默认操作,然后根据我们的 XMLHttpRequest 脚本。
这是我在检查 Httpfox 中显示错误为NS_BINDING_ABORTED的标头后才知道的。
将输入类型从提交更改为按钮后,一切正常。

于 2013-04-08T17:12:50.020 回答