`

用jsonp实现跨域访问

阅读更多
需要实现跨域访问,无非就那么几种方式,其中jsonp是最为理想的方式,由于jsonp属于非正式协议,所以安全性就受到质疑。但是不妨碍我们使用其实现我们的跨域访问。

   要使用jsonp完成跨域放访问,首先要熟悉他的原理。

 

   首先在客户端注册一个callback, 然后把callback的名字传给服务器(此回调函数名字可以不带)。此时,服务器先生成 json 数据。 
然后以 javascript 语法的方式,生成一个function , function 名字就是传递上来的参数 jsonp.最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。客户端浏览器,解析script标签,并执行返回的 javascript 文档,此时数据作为参数,传入到了客户端预先定义好的 callback 函数里.(动态执行回调函数)

 

  使用JSONP技术时,一般是由JS在客户端页面中动态插入script标签,将其src属性设置为带参数的URL。当页面加载时,前述URL会将 参数通过GET请求发送到相应服务器端应用程序(由URL表示),服务器根据参数返回数据——注意,这个数据格式是JSON,并且(注意)被包含在一个函 数调用中,例如:callback({json_data})。这样,在客户端页面中存在预定义的callback(data)函数的定义时,服务器返回 的函数调用就会立即执行,由客户端的函数对数据进行操作。

 

动态生成script并在页面加载完成后跨域访问:

         $(document).ready(function (){                      // 调用JSONP服务器,url为请求服务器地址
        var script =document.createElement("script");  
        script.setAttribute("type", "text/javascript");
        script.setAttribute("src",“此处放置你需要跨越访问的url”);
        script.setAttribute("id", url);
        document.appendChild(script);});

 

===========Javascript代码段:JSONP客户端对服务器开放的接口方法,即回调函数=======================

    function jsonpCallback(obj){
        alert(obj.msg);
    }
------------------END------------------------

 

===============服务器端代码==================

    服务器端可以通过

java.io.PrintWriter out = getResponse().getWriter();

out.println("jsonpCallback({msg:'需要传递的数据',name:'需要传递的数据'})");

out.close();

    将需要传递的数据通过设置到回调函数中进行传递。

 

    注意:jsonpCallback({msg:'需要传递的数据',name:'需要传递的数据'})会在返回客户端的时候自动按照JavaScript语法将数据注入之,如果jsonpCallback函数在客户端没有预先定义,那么将会报找不到该函数的错误。
分享到:
评论

相关推荐

    跨域访问禁止以及使用JSONP实现跨域的示例

    在标题"跨域访问禁止以及使用JSONP实现跨域的示例"中,我们将探讨如何应对这一挑战,特别是通过JSONP技术来突破限制。 首先,我们要理解什么是跨域。跨域是指一个域下的文档或脚本试图请求另一个域下的资源。比如,...

    使用JSONP完成HTTP和HTTPS之间的跨域访问

    使用 JSONP 完成 HTTP 和 HTTPS 之间的跨域访问 知识点一: 什么是 JSONP ...通过了解 JSONP 的工作原理、使用场景、优点和缺点,我们可以更好地使用 JSONP 实现跨域访问,提高应用程序的安全性和性能。

    JSONP实现Ajax跨域访问

    ### JSONP实现Ajax跨域访问 #### 一、引言 JSONP(JSON with Padding)是一种用于解决跨域数据访问的技术。由于同源策略(Same-Origin Policy)的存在,JavaScript/Ajax只能请求同源的资源,这给需要跨域访问数据...

    跨域访问解决方法-jsonp

    跨域访问是Web开发中一个常见的挑战,尤其是在进行Ajax异步请求时,浏览器的同源策略(Same-origin policy)会限制JavaScript从一个源获取另一个源的数据。为了解决这个问题,开发者通常采用JSONP(JSON with ...

    jquery下利用jsonp跨域访问实现方法

    总之,jQuery通过`$.getJSON()`和JSONP机制为开发者提供了一种简单的方式来实现跨域数据请求,使得在前后端分离的架构中,前端可以轻松地获取和处理来自其他域的数据。虽然有一些限制,但在许多场景下,JSONP仍然是...

    使用Jsonp方式跨域获取json

    由于`<script>`标签不受同源策略限制,因此可以实现跨域数据传输。 2. JSONP的工作原理: - 客户端:在HTML页面中,创建一个`<script>`标签,其`src`属性指向服务器上的JSONP接口,同时传递一个回调函数名作为参数...

    html通过 ajax jsonp跨域请求接收和传送数据

    为实现跨域,我们可以使用CORS(Cross-Origin Resource Sharing)机制。服务器需要在响应头中添加`Access-Control-Allow-Origin`字段,允许特定的源进行跨域访问。客户端的AJAX请求设置`xhr.open('GET', url, true)`...

    JSONP解决跨域问题

    JSONP(JSON with Padding)是一种跨域数据交互协议,它利用了`<script>`标签可以跨域请求资源的特性,为了解决JavaScript在浏览器端由于同源策略限制无法直接访问不同源的HTTP请求的问题。在本场景中,前端使用...

    使用jsonp实现跨域获取数据实例讲解

    在本文中,我们将深入理解JSONP的工作原理,并通过实例来演示如何使用JSONP来获取跨域数据。 1. 同源策略:同源策略是浏览器为了安全考虑而设置的一项机制,它限制了脚本只能访问与当前页面具有相同协议(如HTTP或...

    jsonp和跨域1

    总结,跨域问题可以通过JSONP方法来解决,它利用了标签的特性绕过同源策略,通过动态创建标签并指定src属性指向跨域的JSON数据源,再由服务器返回包裹在回调函数中的数据,从而实现跨域数据的获取。这种方法在需要向...

    jsonp实现跨域

    JSONP(JSON with Padding)是一种跨域数据交互协议,它利用了HTML的`<script>`标签可以跨域请求资源的特点,来实现JavaScript从一个域获取另一个域的数据。在Web开发中,由于同源策略的限制,JavaScript通常不能...

    jquery下利用jsonp跨域访问实现方法.docx

    JSONP(JSON with Padding)...总之,JSONP是jQuery中实现跨域访问的一种常见方法,尤其在不支持CORS的旧浏览器环境中非常有用。但随着技术的发展,CORS已成为更推荐的跨域解决方案,因为它提供了更多的控制和安全性。

    Vue项目中使用jsonp抓取跨域数据的方法

    在前端开发中,由于浏览器的同源策略限制,...这种方式使得在Vue项目中实现跨域数据获取变得简单且易于管理。通过这样的实践,开发者可以在不违反同源策略的情况下,从其他域名获取数据,从而丰富和扩展Vue应用的功能。

    jsonp跨域解决源代码

    2. JSONP原理:JSONP的基本思想是,服务器提供一个可以接受参数的JavaScript函数名,客户端在请求时传递这个函数名,服务器返回一个调用该函数并带有JSON数据的脚本,`<script>`标签加载这个脚本,从而实现跨域数据...

    bboss mvc 通过jsonp实现跨站跨域远程访问

    标题 "bboss mvc 通过jsonp实现跨站跨域远程访问" 涉及到的主要知识点是关于Web开发中的跨域通信技术,特别是利用JSONP(JSON with Padding)来解决AJAX请求时遇到的同源策略限制。在互联网应用中,浏览器的安全策略...

    AJax与Jsonp跨域访问问题小结

    AJAX与JSONP跨域访问问题小结 ...内容涵盖了从创建XMLHttpRequest对象,到使用AJAX发起异步请求,再到通过JSONP实现跨域访问的一系列知识点。对于开发者而言,这些内容都是实现现代Web应用中不可或缺的重要技术。

Global site tag (gtag.js) - Google Analytics