Java跨域问题的处理详解

作者:谢小飞 时间:2021-07-05 12:55:18 

前言

相信大家在写前端脚本的时候经常会遇到发送数据到后台的情况,但是由于浏览器的限制,不同域名之间的数据是不能互相访问的,那前端怎么和后端如何进行数据之间的交换呢?

JavaScript由于安全性方面的考虑,不允许页面跨域调用其他页面的对象,那么问题来了,什么是跨域问题?

答:这是由于浏览器同源策略的限制,现在所有支持JavaScript的浏览器都使用了这个策略。那么什么是同源呢?所谓的同源是指三个方面“相同”:

  1. 域名相同

  2. 协议相同

  3. 端口相同

下面就举几个例子来帮助更好的理解同源策略。

URL说明是否允许通信
http://www.a.com/a.js 
     http://www.a.com/b.js
同一域名允许
http://www.a.com/a.js 
     http://www.b.com/a.js
不同域名不允许
http://www.a.com:8000/a.js
     http://www.a.com/b.js
同一域名不同端口不允许
https://www.a.com/a.js 
     http://www.a.com/b.js
同一域名不同协议不允许

在JAVA中处理跨域问题,通常有以下两种常用的解决方法。

第一种解决方法

后台代码在被请求的Servlet中添加Header设置:


response.setHeader("Access-Control-Allow-Origin", "*");
PrintWriter out =null;
try
{
out = response.getWriter();
} catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
out.print("{'status':'ok'}");
out.flush();
out.close();

Access-Control-Allow-Origin这个Header在W3C标准里用来检查该跨域请求是否可以被通过,如果值为*则表明当前页面可以跨域访问。默认的情况下是不允许的。

在前端JS中需要向Servlet发出请求,请求代码如下所示:


$.ajax({
url: "your url",
type:"get or post",
dataType:"json",
data:{
....
},
success:function(data){
...
}

第二种解决方法

通过jsonp跨域请求的方式。JSONP和JSON虽然只有一个字母的区别,但是他们完全就是两回事,很多人很容易把他们搞混。JSON是一种数据交换的格式,而JSONP则是一种非官方跨域数据交互协议。

首先来说一下前端JS是怎么发送请求。代码如下所示:


$.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)。

下面,最重要的来了,后台怎么样获取和返回数据呢。代码如下所示:


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返回的数据就是这样的:


success_jsonpCallback({'status':'ok'})

浏览器会自动解析为json对象,这时候你只需要在success回调函数中直接用data.status就可以了。

来源:http://xieyufei.com/2016/05/28/Java-Ajax.html

标签:java,跨域
0
投稿

猜你喜欢

  • java LockSupport实现原理示例解析

    2023-05-14 06:43:05
  • Mybatis示例讲解注解开发中的单表操作

    2023-08-20 06:20:58
  • Eclipse打开时“发现了以元素'd:skin'”开头的无效内容。此处不应含有子元素的解决方法

    2022-11-24 17:54:50
  • java定义二维数组的几种写法(小结)

    2021-07-05 11:52:09
  • python和JavaScript通信

    2023-02-20 19:40:23
  • Android开发之开关按钮用法示例

    2021-12-24 22:16:11
  • servlet异步请求的实现

    2023-07-14 17:11:38
  • Java实现插入排序实例

    2023-02-13 17:09:21
  • 解决Maven本地仓库明明有对应的jar包但还是报找不到的问题

    2022-07-21 23:12:07
  • 深入浅出MyBatis中映射文件和实体类的关联性

    2022-08-29 07:34:08
  • 结合.net框架在C#派生类中触发基类事件及实现接口事件

    2022-02-23 20:39:57
  • C#实现发送手机验证码功能

    2022-01-11 18:49:57
  • 解决logback-classic 使用testCompile的打包问题

    2021-07-01 08:16:50
  • SpringBoot Entity中枚举类型详细使用介绍

    2023-11-11 00:30:52
  • 浅谈android Fragment横竖屏翻转对重新加载的要求

    2023-07-27 21:55:28
  • Java的外部类为什么不能使用private和protected进行修饰的讲解

    2023-06-29 00:45:57
  • Java中的Set、List、Map的用法与区别介绍

    2022-10-03 04:11:48
  • Android自定义processor实现bindView功能的实例

    2023-09-07 17:16:37
  • Java递归运行的机制:递归的微观解读图文分析

    2022-09-24 20:04:09
  • ActiveMQ安装及部署教程图解

    2023-11-17 18:01:46
  • asp之家 软件编程 m.aspxhome.com