星空网 > 软件开发 > Java

Node.js返回JSONP

  在使用JQuery的Ajax从服务器请求数据或者向服务器发送数据时常常会遇到跨域无法请求的错误,常用的解决办法就是在Ajax中使用JSONP。基于安全性考虑,浏览器会存在同源策略,然而<script/>标签却具有跨域访问数据的能力,这就是JSONP工作的基本原理。有关同源策略以及什么是JSONP,可以参考园子里的这篇文章http://www.cnblogs.com/yuzhongwusan/archive/2012/12/11/2812849.html

  在Node.js中实现JSONP非常简单,通过下面的代码我们从服务器返回并运行一个JavaScript函数,这个JavaScript函数已经在调用方提前被定义好了,于是当它被返回的时候就自动执行了。

var express = require('express');var router = express.Router();router.get('/getinfo', function(req, res, next) { var _callback = req.query.callback; var _data = { email: 'example@163.com', name: 'jaxu' }; if (_callback){   res.type('text/javascript');   res.send(_callback + '(' + JSON.stringify(_data) + ')'); } else{   res.json(_data); }});module.exports = router;

  代码中必须规定从服务器返回数据的类型,代码res.type('text/javascript')被加在返回的数据之前用于告诉浏览器这是一段JavaScript代码。

  前端页面通过JQuery调用:

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>jsonp test</title>  <script src='/images/loading.gif' data-original="http://www.cnblogs.com//bower_components/jquery/dist/jquery.js"></script></head><body>  <input type="button" value="click" id="btn">  <script type="text/javascript">    $(function(){      $('#btn').on('click', function(){        $.get('http://anothersite/api/getinfo', function(d){          console.log(d);        }, 'jsonp');      });    });  </script></body></html>

  运行代码,点击按钮,在浏览器的console面板总我们可以看到从远程服务器返回的json对象。

Node.js返回JSONP




原标题:Node.js返回JSONP

关键词:JS

JS
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

泰国货运运输专线:https://www.goluckyvip.com/tag/88071.html
东莞泰国陆运专线:https://www.goluckyvip.com/tag/88072.html
现在可以发物流到泰国吗:https://www.goluckyvip.com/tag/88073.html
发货到泰国走什么物流:https://www.goluckyvip.com/tag/88074.html
东莞泰国专线:https://www.goluckyvip.com/tag/88075.html
东莞泰国物流专线:https://www.goluckyvip.com/tag/88076.html
武陵山大裂谷周围景点 武陵山大裂谷周围景点图片:https://www.vstour.cn/a/411233.html
南美旅游报价(探索南美洲的旅行费用):https://www.vstour.cn/a/411234.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流