Javascript实现简单跨域调用

什么是JSONP?

1、一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面、动态网页、web服务、WCF,只要是跨域请求,一律不准;

2、不过我们又发现,Web页面上调用js文件时则不受是否跨域的影响(不仅如此,我们还发现凡是拥有"src"这个属性的标签都拥有跨域的能力,比如<script>、<img>、<iframe>);

3、于是可以判断,当前阶段如果想通过纯web端(ActiveX控件、服务端代理、属于未来的HTML5之Websocket等方式不算)跨域访问数据就只有一种可能,那就是在远程服务器上设法把数据装进js格式的文件里,供客户端调用和进一步处理;

4、恰巧我们已经知道有一种叫做JSON的纯字符数据格式可以简洁的描述复杂数据,更妙的是JSON还被js原生支持,所以在客户端几乎可以随心所欲的处理这种格式的数据;

5、这样子解决方案就呼之欲出了,web客户端通过与调用脚本一模一样的方式,来调用跨域服务器上动态生成的js格式文件(一般以JSON为后缀),显而易见,服务器之所以要动态生成JSON文件,目的就在于把客户端需要的数据装入进去。

6、客户端在对JSON文件调用成功之后,也就获得了自己所需的数据,剩下的就是按照自己需求进行处理和展现了,这种获取远程数据的方式看起来非常像AJAX,但其实并不一样。

7、为了便于客户端使用数据,逐渐形成了一种非正式传输协议,人们把它称作JSONP,该协议的一个要点就是允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。

举个最简单的解决方案:

先看一个页面位于AAA.COM的域上,代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
  <title>AAA.COM域上的文件</title>
  <script type="text/javascript">
    function result(data){
        alert(data);
    }
  </script>
  <script type="text/javascript" src="http://www.bbb.com/JsonpServlet?callBack=result"></script>
 </head>

 <body>
 
 </body>
</html>

 

在上述代码中,一个script标签使用src属性,请求了一个非同源位置上的一个java语言的Servlet,下面来看一下该Servlet相对应的代码:

package com.hisicom.servlet;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class JsonpServlet extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html");
        //获取传过来的回调函数名称
        String callBackName = request.getParameter("callBack");
        //处理业务逻辑拼接json串
        String json = "{\"name\":\"jack\",\"sex\":\"man\"}";
        //设置响应类型
        response.setContentType("application/json");
        //将json数据返回给请求页面
        response.getWriter().write(callBackName + "(" + json + ")");
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request, response);
    }
}

这样我们就就完成了一个最简单的跨域调用,怎么样,简单吧。马上动手试一下哇!


 

posted @ 2013-12-06 15:25  ITeachYou我教你  阅读(396)  评论(0编辑  收藏  举报