我遇到一个奇怪的问题,即使http请求中存在该值,发送到我的Web服务的数据仍为null。这是ajax和休息:
$("#updateProfileInfo").click(function(e){
e.preventDefault();
var jobb = $("#jobbEditBox").val();
var bostad = $("#bostadEditBox").val();
var intressen = $("#intresseEditBox").val();
alert(jobb);
alert(bostad);
alert(intressen);
$.ajax({
type: "post",
url: "http://localhost:8080/fakebook/fakebookrest/UserInfoService/json/edituserprofile",
data: {
"jobb" : jobb,
"bostad" : bostad,
"intressen" : intressen
},
success: function(data){
var jsonData = $.parseJSON(data);
alert(jsonData);
}
});
});
@POST
@Path("/json/edituserprofile")
@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
@Produces(MediaType.APPLICATION_JSON)
public boolean produceJSON(
@QueryParam("jobb") String rawJobText,
@QueryParam("bostad") String rawCityText,
@QueryParam("intressen") String rawIntresseText,
@Context HttpServletRequest request)
{
System.out.println(rawJobText);
User user = (User) request.getSession().getAttribute("user");
System.out.println(""+user.getId());
if(user != null)
return userFacade.editProfileInformation(user.getId(), rawJobText, rawCityText, rawIntresseText);
else
return false;
}
Everthing else工作正常,没有错误。还调用了回调函数。唯一的问题是System.out.println(rawJobText);
的值为空。
答案 0 :(得分:0)
您需要使用@FormParam而不是@QueryParam
答案 1 :(得分:0)
老实说,你可能不一定使用@FormParam。您可以做的是转到防火墙并允许连接到Web服务所在的端口。通过允许端口,防火墙不再阻止对数据的访问。如果您确定您的Web服务是准确的,这将有效。您可以使用Postman测试您的Web服务并查看它应该返回的值。