передача параметров запроса из jQuery в сервис джерси с использованием json - PullRequest
0 голосов
/ 15 июня 2010

я пытаюсь отправить (междоменный) некоторые данные в веб-службу Джерси и получить ответ (объект GenericEntity). Сообщение успешно отображается в моей конечной точке Джерси, однако, когда я извлекаю параметры из запроса, они пусты ..

$ .ajax({
   type: "POST",
   dataType: "application/json; charset=utf-8",
   url: jerseyNewUserUrl+'?jsoncallback=?',
   data:{'id':id, 'firstname':firstname,'lastname':lastname},
   success: function(data, textStatus) {
   $('#jsonResult').html("some data: " + data.responseMsg);
            },
   error: function ( XMLHttpRequest, textStatus, errorThrown){
    alert('error');
     }
  });

это моя конечная точка на майке ..

@POST
    @Produces( { "application/x-javascript", MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML })
    @Path("/new")
    public JSONWithPadding addNewUser(@QueryParam("jsoncallback")
    @DefaultValue("empty")
    final String argJsonCallback, @QueryParam("id")
    final String argID, @QueryParam("firstname")
    final String argFirstName, @QueryParam("lastname")
    final String argLastName)

что-то не хватает в моем вызове $ .ajax?

Ответы [ 2 ]

1 голос
/ 03 ноября 2010

вы не можете использовать @QueryParam для получения значений. Вы можете использовать объект для получения значений. Вот так

@POST  
@Produces( { "application/x-javascript", MediaType.APPLICATION_JSON,MediaType.APPLICATION_XML})  
@Path("/new")  
public void addNewUser(User user){  
    //NB User has to have the following field names id', firstname,lastname  
}  
1 голос
/ 15 июня 2010

Попробуйте это:

$ .ajax({
   type: "POST",
   dataType: "jsonp",
   jsonp: "fooCallBackFunction",
   url: jerseyNewUserUrl,
   data:{'id':id, 'firstname':firstname,'lastname':lastname},
   success: function(data, textStatus) {
   $('#jsonResult').html("some data: " + data.responseMsg);
            },
   error: function ( XMLHttpRequest, textStatus, errorThrown){
    alert('error');
     }
  });
...