$ .ajax和JSONP。 ParseError和Uncaught SyntaxError:意外的令牌:
首先,我一直在寻找几个主题中我的问题的答案,我找不到适用于我的代码的解决方案。
我试图从servlet获得答案,如果我去http://XXXZZZ/Servlet/Login?login=pepe&pass=1234
我按预期收到有效的JSON:
{"id":3,"login":"pepe","key":"0D1DBA4BE87E02D43E082F9AA1ECFDEB"}
但是当我尝试使用$ .ajax时,我得到2个错误。
$.ajax({ type : "Get", url :"http://XXXZZZ/Servlet/Login", data :"login="+login+"&password="+pass, dataType :"jsonp", success : function(data){ alert(data);}, error : function(httpReq,status,exception){ alert(status+" "+exception); } });
第一个错误(在弹出窗口中):
parsererror Error: jQuery17104145435250829905_1336514329291 was not called
第二个错误(在Chrome控制台中):
Uncaught SyntaxError: Unexpected token : Login 1
(还有我正在等待的JSON)。
PS我必须使用dataType:“jsonp”,因为如果我使用“json”,我也会遇到跨域问题。
如果您使用的是jsonp,则语法错误
你需要回来
myJsonMethod({"id":3,"login":"pepe","key":"0D1DBA4BE87E02D43E082F9AA1ECFDEB"});
并添加到您的ajax请求选项
jsonp: false, jsonpCallback: "myJsonMethod"
所以
$.ajax({ type : "Get", url :"http://XXXZZZ/Servlet/Login", data :"login="+login+"&password="+pass, dataType :"jsonp", jsonp: false, jsonpCallback: "myJsonMethod", success : function(data){ alert(data);}, error : function(httpReq,status,exception){ alert(status+" "+exception); } });
( 当然,正如@voyager指出的那样确定了success
)
succes : function(data){
这是一个错字:
success : function(data){
首先,你的成功参数中有一个拼写错误; 你错过了结局。 此外,当您执行JSONP请求时,您需要以JSONP格式返回JSON信息; 其中应包含回调标记作为返回字符串的一部分。 一个示例JSONP字符串看起来像这样:
yourcallbacktoken({"id":3,"login":"pepe","key":"0D1DBA4BE87E02D43E082F9AA1ECFDEB"})
有关JSONP规范的更多信息,请查看此页面: http : //devlog.info/2010/03/10/cross-domain-ajax/