无法将json参数传递给Jersey @POST / GET

时间:2013-05-31 10:16:50

标签: java jquery html json post

我们正在使用带有球衣的动态网络应用程序,客户端是使用phonegap jQuery和Javascript的Android手机。

当用户向Web服务器发送帖子时,它正在获取请求,但没有看到任何参数(@Counsume)。

我知道球衣正在运作,因为当我尝试在其他功能上使用@get方法时,它运行良好。

这是我的代码:

//网络服务器

 package il.ac.hit;
    import java.util.Map;
    import javax.ws.rs.*;
    @Path("/TakeAHikeDao")
    public class TakeAHikeDao
    {
        @POST
        @Path("userCredentialsValidate")
        @Consumes("application/json")
        @Produces("application/text")
        public String userCredentialsValidate(Map<String, String> userCredentials)
        {
            System.out.println(userCredentials.toString()+"%%%");
            return ("{\"status\":\"success\"}");    
        }
    }

// web.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>TakeAHikeServerSide</display-name>
  <servlet>
    <servlet-name>Jersey REST Service</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
    <init-param>
        <param-name>com.sun.jersey.config.property.packages</param-name>
        <param-value>il.ac.hit</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Jersey REST Service</servlet-name>
    <url-pattern>/rest/*</url-pattern>
  </servlet-mapping> 
</web-app>

//带有javascript代码的客户端HTML

<script language="JavaScript" charset="utf-8>
function checkUser() 
{

var url=localhost:8080/rest/TakeAHikeDao/userCredentialsValidate

$.post("url",{"username":"dan","password":"123456"},function( data ) {
        alert( "JSON Data: " + data);
        });

/*  this is the second option we tried
    $.get("url",{"username":"dan","password":"123456"},function( data ) {
        alert( "JSON Data: " + data);
        });
*/

 /* this is the third option we tried       
    $.getJSON("url",{"username":"dan","password":"123456"},function( data ) {
            alert( "JSON Data: " + data);
            });
 */
}
</script>

//this is the button calling the function.
<a href="#" data-role="button" data-icon="arrow-r" onClick="checkUser()">SUBMIT</a>

我在控制台中从方法中收到的输出:

System.out.println(userCredentials.toString()+"%%%");

是“%%%”(userCredentials为空,无法获取已发送的数据)。

提前致谢, 奥菲尔。

2 个答案:

答案 0 :(得分:0)

您是否尝试过更改方法签名以取代强类型参数名称而不是通用参数?

答案 1 :(得分:0)

我很高兴地说我发现了这个问题, 这些变化取决于消费:

@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
@Produces(MediaType.APPLICATION_JSON)
MultiValuedMap<String, String> userCredentials

@POST
@Path("userCredentialsValidate")
@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
@Produces(MediaType.APPLICATION_JSON)   
public String userCredentialsValidate(MultiValuedMap<String, String> userCredentials)
{
        System.out.println(userCredentials.toString()+"%%%");
        return ("{\"status\":\"success\"}");
}

我希望这会对你有所帮助。