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的跨域请求的主要内容,如果未能解决你的问题,请参考以下文章

关于AJAX请求的跨域问题以及JSONP的示例

CORS - 没有 JSONP 的跨域 AJAX 通过允许服务器上的 Origin

JQuery - $.ajax() - 使用 JSONP 的跨域 - 仅在 IE 8 中获取“解析器错误”(在 IE 7 中工作)

ajax遇到的跨域问题

chrome下如何实现ajax的跨域访问

JQUERY的AJAX中 get()post()的跨域方法