Java实现CORS跨域请求的实现方法

2025-05-29 0 99

问题

使用前后端分离模式开发项目时,往往会遇到这样一个问题 — 无法跨域获取服务端数据

这是由于浏览器的同源策略导致的,目的是为了安全。在前后端分离开发模式备受青睐的今天,前端和后台项目往往会在不同的环境下进行开发,这时就会出现跨域请求数据的需求,目前的解决方案主要有以下几种:

JSONP、iframe、代理模式、CORS等等
前面几种方式在这里不讲,网上有很多资料。在这里我主要分享一下CORS这种解决方式,CORS即“跨域资源共享”,它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制。

使用 CORS 跨域的时候和普通的 ajax 过程是一样的,只是浏览器在发现这是一个跨域请求的时候会自动帮我们处理一些事情,所以说只要服务端提供支持,前端是不需要做额外的事情的。

实现

实现的大概思路是这样的,首先使用过滤器获取请求对象request的信息,比如Origin 字段(表示请求来自哪个源,包括协议、域名、端口),通过预先配置的参数判断请求是否合法,然后设置响应对象response的头信息,实现跨域资源请求。在介绍实现方式之前我们先来了解一下会用到的响应头信息。

响应头

Access-Control-Allow-Methods
用来列出浏览器的CORS请求允许使用的HTTP方法,如:GET、POST、PUT、DELETE、OPTIONS

Access-Control-Allow-Credentials
表示是否支持跨域Cookie

Access-Control-Allow-Headers
逗号分隔的字符串,表示服务器支持的所有头信息字段,如Content-Type以及自定义的字段

Access-Control-Expose-Headers
与“Access-Control-Allow-Headers”相反,表示不支持的头信息字段

Access-Control-Allow-Origin
允许跨域的请求源信息,包括协议、域名、端口,为*表示允许所有请求来源,并且只能设置一个请求源

下面介绍一下Java后台如何实现这种方式。

代码

由于最近在使用spring-boot,所以接下来以spring-boot为基础来实现。

首先创建一个CorsFilter过滤器,代码如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60
...

@WebFilter(filterName = "corsFilter", urlPatterns = "/*",

initParams = {@WebInitParam(name = "allowOrigin", value = "*"),

@WebInitParam(name = "allowMethods", value = "GET,POST,PUT,DELETE,OPTIONS"),

@WebInitParam(name = "allowCredentials", value = "true"),

@WebInitParam(name = "allowHeaders", value = "Content-Type,X-Token")})

public class CorsFilter implements Filter {

private String allowOrigin;

private String allowMethods;

private String allowCredentials;

private String allowHeaders;

private String exposeHeaders;

@Override

public void init(FilterConfig filterConfig) throws ServletException {

allowOrigin = filterConfig.getInitParameter("allowOrigin");

allowMethods = filterConfig.getInitParameter("allowMethods");

allowCredentials = filterConfig.getInitParameter("allowCredentials");

allowHeaders = filterConfig.getInitParameter("allowHeaders");

exposeHeaders = filterConfig.getInitParameter("exposeHeaders");

}

@Override

public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {

HttpServletRequest request = (HttpServletRequest) servletRequest;

HttpServletResponse response = (HttpServletResponse) servletResponse;

if (!StringUtils.isEmpty(allowOrigin)) {

if(allowOrigin.equals("*")){

response.setHeader("Access-Control-Allow-Origin", allowOrigin);

}else{

List<String> allowOriginList = Arrays.asList(allowOrigin.split(","));

if (allowOriginList != null && allowOriginList.size() > 0) {

String currentOrigin = request.getHeader("Origin");

if (allowOriginList.contains(currentOrigin)) {

response.setHeader("Access-Control-Allow-Origin", currentOrigin);

}

}

}

}

if (!StringUtils.isEmpty(allowMethods)) {

response.setHeader("Access-Control-Allow-Methods", allowMethods);

}

if (!StringUtils.isEmpty(allowCredentials)) {

response.setHeader("Access-Control-Allow-Credentials", allowCredentials);

}

if (!StringUtils.isEmpty(allowHeaders)) {

response.setHeader("Access-Control-Allow-Headers", allowHeaders);

}

if (!StringUtils.isEmpty(exposeHeaders)) {

response.setHeader("Access-Control-Expose-Headers", exposeHeaders);

}

filterChain.doFilter(servletRequest, servletResponse);

}

@Override

public void destroy() {

}

}

大功告成,现在前端就可以跨域获取后台的数据了,比其它方式容易得多,代码就不解释了,简单易懂,使用其它后台开发方式也一样,最终目的就是判断请求,设置响应头,前端什么事都不用做。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:http://www.jianshu.com/p/d6dc9e60c8e6?utm_source=tuicool&utm_medium=referral

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Java实现CORS跨域请求的实现方法 https://www.kuaiidc.com/114862.html

相关文章

发表评论
暂无评论