专栏首页王二麻子IT技术交流园地Javascript实现简单跨域调用

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);
    }
}

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 十、VueJs 填坑日记之在项目中使用Amaze UI

    上一篇博文,我们把jQuery集成到了项目中,今天我们来集成Amaze ui(妹子UI)。先来介绍一下妹子UI。Amaze UI 含近 20 个 CSS 组件、...

    I Tech You_我教你
  • Java POI Word 写文档

    package apache.poi; import java.io.ByteArrayInputStream; import java.io.ByteArr...

    I Tech You_我教你
  • 《SpringMVC从入门到放肆》七、模型与视图ModelAndView

    上一篇我们了解了开发一个Controller的4种方法,如果不记得的朋友可以看看上一篇博文,今天我们来继续了解SpringMVC的模型与视图ModelAndVi...

    I Tech You_我教你
  • Go语言实现TCP通信

    问题: 如何区分 c net.Conn 的 Write 与 Read 的数据流向?

    用户1081422
  • jsonp介绍与jsonp封装

    游魂
  • 装饰器模式4(javascript版)4

    贵哥的编程之路
  • 运用Kotlin进行SpringBoot入门开发

    Kotlin可以与Java无缝对接,之前我们搞了Kotlin入门,我们今天试试Kotlin进行SpringBoot开发吧

    大话swift
  • 每个数据科学家都应该学习4个必备技能

    IT派 - {技术青年圈} 持续关注互联网、大数据、人工智能领域 摘要: 作为一个数据科学家你必须要掌握的四个必备技能,值得每个想要成为数据科学家和已经成为...

    IT派
  • 每个数据科学家都应该学习4个必备技能

    摘要: 作为一个数据科学家你必须要掌握的四个必备技能,值得每个想要成为数据科学家和已经成为数据科学家的人去学习。 这篇文章对应之前发表过的一篇关于如何成长为一名...

    企鹅号小编
  • 「自然语言处理(NLP)」良心推荐:一文了解注意力机制(Attention)

    相信很多小伙伴在看论文的时候,会时不时的遇到注意力机制(Attention)这个关键词。其实注意力模型最近几年在深度学习各个领域被广泛使用,无论是在图像...

    ShuYini

扫码关注云+社区

领取腾讯云代金券