zoukankan      html  css  js  c++  java
  • ajax如何决绝跨域问题

    跨域报错截图
    通过jsonp跨域请求的方式。JSONP和JSON虽然只有一个字母的区别,但是他们完全就是两回事,很多人很容易把他们搞混。JSON是一种数据交换的格式,而JSONP则是一种非官方跨域数据交互协议。
    首先来说一下前端JS是怎么发送请求。代码如下所示:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    $.ajax({
     url:"your url",
     type:"get or post",
     async:false,
     dataType : "jsonp",
     //服务端用于接收callback调用的function名的参数
     jsonp:"callbackparam",
     //callback的function名称
     jsonpCallback:"success_jsonpCallback",
     success:function(data){
     console.log(data);
     },
     error:function(data){
     console.log(data);
     }
    });
    这里的callbackparam和success_jsonpCallback可以理解为发送的data数据的键值对,可以自定义,但是callbackparam需要和后台约定好参数名称,因为后台需要获取到这个参数里面的值(即success_jsonpCallback)。
    下面,最重要的来了,后台怎么样获取和返回数据呢。代码如下所示:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    PrintWriter out =null;
    String callback=req.getParameter("callbackparam");
    String json=callback+"({'status':'ok'})";
    try
    {
     out = resp.getWriter();
    } catch (IOException e)
    {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
    out.print(json);
    out.flush();
    out.close();
    首先需要获取参数名为callbackparam的值,这里获取到的值就是“success_jsonpCallback”。然后将这个值加上一对小括号。小括号里放入你需要返回的数据内容,比如这里我返回一个JSON对象。当然你也可以返回其他对象,比如只返回一个字符串类型数据也可以。最后前端JS返回的数据就是这样的:
    1
    success_jsonpCallback({'status':'ok'})
    浏览器会自动解析为json对象,这时候你只需要在success回调函数中直接用data.status就可以了。

  • 相关阅读:
    利用CMD查看系统硬件信息
    固定资产分类(仅供参考 2005年),
    批量查询数据表的标识值的方法
    安装完office2016 64位后,在安装visio时,报错,无法安装,
    安装office2016 64位时提示64位与32位的office程序不兼容,在系统是64位的情况下,由于应用的需要,必须装64位的office,怎么办
    web.config文件详解
    master..xp_fileexist
    IE11快捷键 双击没反应的解决办法
    Grading
    今年第一个扶贫日
  • 原文地址:https://www.cnblogs.com/binghuaZhang/p/13891037.html
Copyright © 2011-2022 走看看