ajax jsonp的跨域请求
Posted ```...简单点
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ajax jsonp的跨域请求相关的知识,希望对你有一定的参考价值。
1.页面ajax的请求
$.ajax({ async: false, url: ‘http://localhost:8080/downloadVideos‘,//跨域的dns/document!searchJSONResult.action, type: "GET", dataType: ‘jsonp‘, jsonp: ‘jsoncallback‘, jsonpCallback: "cb",//自定义返回函数的名称,要与服务端保持一致 data: { id:ID, user:user }, timeout: 5000, success: function (json) { $(data).css("background","red"); alert(json); } });
2.服务端nodeJS的返回
app.get(‘/downloadVideos‘, function (req, res, next) { var random = new Date().getTime(); var url = "https://savemedia.com/generate/"; var videosID = req.query.id; superagent .get(url + videosID + "?random=" + random) .end(function (err, sres) { // callback // 常规的错误处理 if (err) { return next(err); } var obj = JSON.parse(sres.text); var url = obj.download.watch[0].url; var videoName = new Date().getTime(); downloadFile(url, "../public/videos/" + videoName + ".mp4", function (err) { if (err) { return next(err); // console.log(videoName + ".mp4" + ‘下载完毕‘); }); var videoUrl = ‘http://**.**.**.**:8080/videos/‘ + videoName + ‘.mp4‘; res.send("cb(" + JSON.stringify(videoUrl) + ")"); }); });
//文件下载 function downloadFile(uri, filename, callback) { var stream = fs.createWriteStream(filename); request(uri).pipe(stream).on(‘close‘, callback); }
以上是关于ajax jsonp的跨域请求的主要内容,如果未能解决你的问题,请参考以下文章
CORS - 没有 JSONP 的跨域 AJAX 通过允许服务器上的 Origin
JQuery - $.ajax() - 使用 JSONP 的跨域 - 仅在 IE 8 中获取“解析器错误”(在 IE 7 中工作)