我正在尝试使用jQuery的ajax方法从服务器获取数据。
$.ajax({
dataType: "jsonp",
url: "https://secure.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json",
type: "GET",
data: "msg=aaa",
cache: true,
jsonp: "jsoncallback",
// jsonpCallback: "callbackmethod",
success: function(encryptedMsg){
console.log("Encryption success!");
},
error: function(req, errmsg, thrownError) {
console.log("Error: HTTP " + req.status + " " + errmsg);
}
});
但是,错误控制台中会显示以下错误:
Error: jQuery1720502636097747291_1339479763752 is not defined
Source File: https://secure.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=jQuery1720502636097747291_1339479763752&msg=aaa
Line: 1
如果您打开源文件URL,您可以看到以下JSON,它似乎是正确的JSON。
jQuery1720502636097747291_1339479763752({
"title": "Recent Uploads tagged cat",
// ...
"items": [
{
"title": "Chaton",
// ...
},
// ...
]
})
我还尝试用jsonpCallback指定方法名:“callbackmethod”,但它没有用。 我还使用了$ .getJson()方法和jquery-jsonp(http://code.google.com/p/jquery-jsonp/)但结果是一样的。
浏览器是Firefox并使用HTML4。 这用于firefox插件。
您可以在此处阅读完整代码:https://builder.addons.mozilla.org/addon/1048275/revision/749
我在common-content.js
提前致谢。
答案 0 :(得分:3)
不要在Firefox扩展中使用JSONP。如果它有效,那将是一个安全问题,因为它允许一些Web服务器在您的扩展的上下文中运行代码。在你的情况下,它不起作用,因为content scripts don't access the web page directly。 JSONP脚本可以在网页的上下文中运行,无法查看内容脚本定义的函数。
您应该使用request
module向任何Web服务器发出请求,它支持JSON格式。您当然不能从内容脚本中使用它,但是您可以将消息发送回扩展,然后扩展应该发出请求并将服务器响应发送回内容脚本。请参阅communicating with content scripts上的文档。