2013-04-05 120 views
0

我想发布一些JSON数据到泽西框架实现的REST Web服务。我不使用JAXB或jQuery,但只有JavaScript。
我验证过形成的json是正确的,但是尽管设置了内容类型“application/json”,但在服务器上它被接收为“application/x-www-form-urlencoded”。
这里是我的代码:POST JSON到泽西岛服务

<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="[email protected]" /> 
     <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; 
    } 
} 

我新的网络开发和不知道什么我在上面的代码很想念。

+1

这是髋关节,但你有没有尝试在'Content-Type'中't'大写? – 2013-04-05 15:42:17

+0

它只是在大写字母中,但在检查请求标题后用小“t”尝试。仍然没有运气。 – Ashwini 2013-04-05 16:55:08

回答

0

我正在回答我自己的问题,以供稍后访问的人使用。上面的代码是正确的,并且除了URL被击两次这个事实之外运作良好。第一次,提交按钮的默认操作,然后按照XMLHttpRequest的脚本。
在我检查了Httpfox中的头文件后,我发现这个错误显示为NS_BINDING_ABORTED
将提交的输入类型更改为按钮后,所有工作都正常。