从javascript将对象传递给Rest

时间:2012-08-01 16:17:50

标签: java javascript jquery rest

以下是该方案 我有一个REST服务定义如下:

@Path("/company/{companyName}/sessions")
public class RESTSessionController {

    RESTService service = new RESTService();
     @GET
     @Produces({"application/json"})
     @Path("/{username}/{password}") 
     public Result getFriend(@PathParam ("companyName") String companyName ,
             @PathParam ("username") String username,
             @PathParam ("password") String password){

         System.out.println(companyName);
         return service.login(username,password);
     }
}

要打电话给我,我有一个javascript如下:

$.ajax({
    url: 'http://localhost:8888/rest/company/hertz/sessions/amir/help',
    dataType: 'json',
    data: null,
    success: function(data) { 
        $("#abc").html(dumpObj(data,"Result",'',0));
         }
    });

这很好用,我把它拿回来了:

{"code":"200","description":"Amir is now logged in.","payload":{"@type":"xs:string","$":"Amir123"}}

这完全没问题。

现在我正在尝试更进一步,使用对象调用我的服务,所以我将代码更改为:

$.ajax({
    qObj={username:"Amir",password:"123",companyName:"hertz"}
    url: 'http://localhost:8888/rest/company/',
    dataType: 'json',
    data: JSON.stringify(qObj),
    success: function(data) { 
        $("#abc").html(dumpObj(data,"Result",'',0));
         }
    });

它不起作用。

我的问题很简单,如何使用jquery / javascript在路径中(或不使用参数)调用REST服务?

帮助

阿米尔

2 个答案:

答案 0 :(得分:1)

找到解决方案 如果你在寻找相同的答案,我的发现是: 1)您不能将路径中使用的变量用作发送到REST服务的对象的一部分。所以在我的情况下,{companyName}无法真正作为json对象的一部分传递。 2)在方法声明中,它必须是一个指令,指示此方法需要一个json对象,就是这种情况所以我将代码更改为:

 @PUT
 @Produces(MediaType.APPLICATION_JSON)
 @Consumes(MediaType.APPLICATION_JSON)
 @Path("/")
 public API_Session login(API_Session_Request request){

所有人都像魅力一样。

3)在javascript中你应该使用JSON.stringify你的对象:

var qObj={username:"Amir",password:"123",company_name:"hertz"}
$.ajax({
    type:'PUT',
    url: 'http://localhost:8888/rest/company/sessions',
    dataType: 'json',
    data: JSON.stringify(qObj),
    contentType: "application/json; charset=utf-8",
    success: function(data) { 
        $("#abc").html(dumpObj(data,"Result",'',0));
         }
    });

希望这可以帮助您节省一些时间。

答案 1 :(得分:0)

为什么必须使用JSON.stringify?试试这个让我知道:))

$.ajax({
    url: 'http://localhost:8888/rest/company/',
    dataType: 'json',
    data: {username:"Amir",password:"123",companyName:"hertz"},
    success: function(data) { 
        $("#abc").html(dumpObj(data,"Result",'',0));
         }
    });