jquery的ajax和getJson跨域获取json数据(图文教程)

本篇文章主要是对jquery的ajax和getjson跨域获取json数据的实现方法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助

很多开发人员在使用jquery在前端和服务器端进行数据交互,所以很容易会认为在前端利用jquery就可以读取任何站点的数据了。近日在进行开 发时,因为要和第三方公司的一个项目进行数据的共享,因为考虑多不占用服务器的资源,遂决定直接在html进行数据的读取,不走服务器端进行中转了。然后 正好就遇到了浏览器端跨域访问的问题。

跨域的安全限制都是指浏览器端来说的,服务器端不存在跨域安全限制的问题。

目前浏览器端跨域访问常用的两种方法有两种:

1、通过jQuery的ajax进行跨域,这其实是采用的jsonp的方式来实现的。

jsonp是英文json with padding的缩写。它允许在服务器端生成script tags至返回至客户端,也就是动态生成javascript标签,通过javascript callback的形式实现数据读取。

html页面端示例代码:

//首先要引入jquery的js包jQuery(document).ready(function(){$.ajax({type : "get", //jquey是不支持post方式跨域的async:false,url : "http://api.taobao.com/apitools/ajax_props.do", //跨域请求的URLdataType : "jsonp",//传递给请求处理程序,用以获得jsonp回调函数名的参数名(默认为:callback)jsonp: "jsoncallback",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名jsonpCallback:"success_jsonpCallback",//成功获取跨域服务器上的json数据后,会动态执行这个callback函数success : function(json){alert(json);}});});

登录后复制

服务器端示例代码,以java为例:

服务器端代码,是重点,开始以为,只要客户端通过jsonp就可以直接跨域访问,其实不然,需要服务器端的支持才行。

public void jsonpTest() throws IOException{HttpServletRequest request = ServletActionContext.getRequest();HttpServletResponse response = ServletActionContext.getResponse();//根据html指定的jsonp回调函数的参数名,获取回调函数的名称//callbackName的值其实就是:success_jsonpCallbackString callbackName = (String)request.getAttribute("jsoncallback");//简单模拟一个json字符串,实际可使用google的gson进行转换,次数通过字符串拼接//{"name":"张三","age":28}//是对"号进行转义String jsonStr = "{"name":"张三","age":28}";//最终返回的数据为:success_jsonpCallback({"name":"张三","age":28})String renderStr = callbackName+"("+jsonStr+")";response.setContentType("text/plain;charset=UTF-8");response.getWriter().write(renderStr);}

登录后复制

jsonp的原理:

首先在客户端注册一个callback (如:’jsoncallback’), 然后把callback的名字(如:success_jsonpCallback)传给服务器端对应的处理函数。

服务器先生成需要返回给客户端的 json 数据。然后以 javascript 语法的方式,生成一个function , function 名字就是传递上来的参数(jsoncallback)的值(success_jsonpCallback) 。

最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。
客户端浏览器,解析script标签,并将服务器端返回的数据,作为参数,
传入到了客户端预先定义好的 callback 函数(如上例中jquery $.ajax()方法封装的的success: function (json))里。

实际上跨域是通过动态增加script来加载数据,无法直接获得数据,所以需要使用回调函数。

2.使用jquery的getJson进行跨域读取数据

实际上getJson方式的根本原理和ajax使用jsonp的方式是一样的。

jquery中常用getJson来调用获取远程的数据,并通过json格式返回。函数的原型如下:

jQuery.getJSON(url,data,success(data,status,xhr))

参数 描述

url必需。规定将请求发送的哪个 URL。data可选。规定连同请求发送到服务器的数据。success(data,status,xhr)

可选。规定当请求成功时运行的函数。

额外的参数:

response – 包含来自请求的结果数据

status – 包含请求的状态

xhr – 包含 XMLHttpRequest 对象

该函数是简写的ajax函数,实际上等价于:

$.ajax({  url: url,  data: data,  success: callback,  dataType: json});

登录后复制

言归正传,下面我们来看如何使用getJson跨域获取数据。

html页面示例代码:

$.getJSON("http://api.taobao.com/apitools/ajax_props.do&jsoncallback=?",    function (data) {        alert(data);    });

登录后复制

执行原理:

发送请求时需要传一个callback的回调函数名到服务器端,服务器端拿到这个回调函数名,再将返回数据用参数的形式反回到客户端,这样客户端就能够调到。

所以发送请求URL的地址后面一定要上jsoncallback=?这样的参数,jquery会将?号自动替换成自动生成的回调函数的名称。

所以最终的实际请求为:http://api.taobao.com/apitools/ajax_props.do&jsoncallback=jsonp1322444422697

所以和ajax的方式想比较,也就是callback函数一个是自动生成的函数名,一个是手工指定的函数名。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

jquery+ajax应用iframe时使其自适应高度

AJAX二级联动有哪些实现方法

jquery+ajax返回json中文乱码现象怎样处理

以上就是jquery的ajax和getJson跨域获取json数据(图文教程)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2760152.html

(0)
上一篇 2025年3月8日 09:03:37
下一篇 2025年3月8日 09:03:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • jQuery 能做什么?

    本篇对jquery的使用做出了相关的总结。 jQuery是一个小巧的,快速的,功能强大的JavaScript库。它通过一些易用的API简化了许多事情,例如:DOM操作、事件监听、动画、AJAX等等。jQuery能做的事情,原生JS都能做到,…

    编程技术 2025年3月8日
    200
  • JS基础-Math数组Date

    本篇讲解了js的基础math数组和date的相关知识。 一.Math 1、写一个函数,返回从min到max之间的 随机整数,包括min不包括max    //不包含最大数    function getNum(min,max){      …

    编程技术 2025年3月8日
    200
  • node.js进入文件目录步骤详解

    这次给大家带来node.js进入文件目录步骤详解,node.js进入文件目录的注意事项有哪些,下面就是实战案例,一起来看一下。 要进入莫一个目录比如:”D:react” 首先要:d: 然后:cd d:eact 如图:…

    2025年3月8日
    200
  • Nodejs内存治理步骤详解

    这次给大家带来Nodejs内存治理步骤详解,Nodejs内存治理的注意事项有哪些,下面就是实战案例,一起来看一下。 s运行的宿主环境不同,相应的对内存治理的要求也不一样,当宿主环境是浏览器时,由于网页的运行时间短,且只运行在用户的机器上(相…

    编程技术 2025年3月8日
    200
  • 原生JS实现Ajax跨域请求flask响应内容(图文教程)

    这篇文章主要为大家详细介绍了js实现ajax跨域请求flask响应内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 Ajax方法好,网站感觉跟高大上,但由于Js的局限,跨域Ajax无法实现,这里,讲一下解决办法,前提是需要能够自己可以…

    编程技术 2025年3月8日
    200
  • nodejs更改项目端口号步骤详解

    这次给大家带来nodejs更改项目端口号步骤详解,nodejs更改项目端口号的注意事项有哪些,下面就是实战案例,一起来看一下。 在项目中加入文件:ServerConf var ServerConf= { ApiHost: “” //后台链接…

    2025年3月8日
    200
  • js中async函数使用方法详解

    这次给大家带来js中async函数使用方法详解,js中async函数使用的注意事项有哪些,下面就是实战案例,一起来看一下。 一、终极解决 异步操作是 JavaScript 编程的麻烦事,麻烦到一直有人提出各种各样的方案,试图解决这个问题。 …

    编程技术 2025年3月8日
    200
  • 编写js async函数步骤详解

    这次给大家带来编写js async函数步骤详解,编写js async函数的注意事项有哪些,下面就是实战案例,一起来看一下。 2018年已经到了5月份,node的4.x版本也已经停止了维护我司的某个服务也已经切到了8.x,目前正在做koa2.…

    编程技术 2025年3月8日
    200
  • jQuery实现无缝轮播与左右点击步骤详解

    这次给大家带来jQuery实现无缝轮播与左右点击步骤详解,jQuery实现无缝轮播与左右点击的注意事项有哪些,下面就是实战案例,一起来看一下。 在网页中我们想要的无缝轮播左右循环有好多好多中,这是我第一个轮播效果,也是最基础的,和大家分享一…

    2025年3月8日 编程技术
    200
  • JS事件绑定、事件流模型案例分析

    这次给大家带来JS事件绑定、事件流模型案例分析,使用JS事件绑定、事件流模型的注意事项有哪些,下面就是实战案例,一起来看一下。  一、JS事件 (一)JS事件分类 1.鼠标事件: click/dbclick/mouseover/mouseo…

    2025年3月8日
    200

发表回复

登录后才能评论