解决 RESTful API 中的跨域问题

阅读时长 4 分钟读完

当我们使用前端调用 RESTful API 时,经常会遇到跨域这个问题。这是因为浏览器出于安全原因,限制了同源策略,不允许网页访问不属于自己域下的资源。本文就来讲解如何解决这个问题。

什么是跨域?

在 Web 开发中,域名(或 IP)+ 端口 + 协议(http/https)共同组成网站地址,如果两个网站地址的域名(或 IP)+ 端口 + 协议 (http/https)中有任何一个不同,就被认为是跨域。例如,www.a.com 这个网站地址和 www.b.com 就是跨域的。

解决跨域问题的方式

下面介绍几种解决跨域问题的方式。

JSONP(JSON with Padding)

JSONP 是一种前端技术,它允许页面从一个不同的域名(跨域)获取数据。JSONP 的原理是,在服务端,JSON 数据被包裹在一个函数调用中返回到页面,浏览器将函数名与返回数据一起传递给客户端的回调函数中。

在前端,使用以下方式进行 JSONP 请求:

服务端返回的数据如下:

这段数据会传到页面上调用 callback 函数。

CORS(Cross-Origin Resource Sharing)

CORS 是 W3C 标准,它是一种允许浏览器向跨域服务器发出 XMLHttpRequest 请求的机制。在服务端,通过设置 Access-Control-Allow-Origin 头部,允许某个指定的域名可以跨域访问它的资源。

以下是使用 CORS 的示例代码:

服务端的 Response Header:

前端的请求代码:

代理

在某些情况下,我们可以使用代理服务器来避免跨域。代理服务器就是让前端的请求先发送到自己的服务器上,再由自己的服务器转发到真正的目标服务器上,最后再将目标服务器的响应返回给前端。

以下是使用代理的示例代码:

前端的请求代码:

代理服务器的代码:

-- -------------------- ---- -------
----- ------- - -------------------
----- ------- - -------------------

----- --- - ----------

--------------- ----- ---- -- -
  --------------------------------------------
---

---------------- -- -- -
  ------------------ ------ -- ------- -- ---- -------
---

总结

以上三种方式都可以解决 RESTful API 中的跨域问题。它们各有优缺点,具体使用应根据项目场景选择合适的方式。在实际项目中,CORS 和代理的方式更为常用。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/645a224d968c7c53b0c43bf3

纠错
反馈