跨域题目?无需担心!学习怎样办理 Axios 的跨域限制

小小小幸运  金牌会员 | 2024-6-24 00:30:00 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 760|帖子 760|积分 2280

跨域是指访问别的一个域的资源,由于浏览器的同源计谋,默认情况下使用 XMLHttpRequest 和 Fetch 请求时是不允许跨域的。跨域的根本原因是浏览器的同源计谋,这是由浏览器对 JavaScript 施加的安全限制。


Axios 跨域常见报错

跨域请求被阻止 (Cross-Origin Request Blocked)
这是由浏览器实施的同源计谋导致的错误。浏览器在默认情况下不允许从一个源发送请求到另一个源,除非目标服务器明确授权。如果没有接纳任何跨域办理方案,浏览器会拦截该请求,并报告此错误。
无法获取相应内容 (No 'Access-Control-Allow-Origin' header is present on the requested resource)
当使用 CORS (跨域资源共享) 办理方案时,服务器须要在相应头中添加 Access-Control-Allow-Origin 头信息来指示允许访问资源的泉源。如果服务器没有正确设置这个头信息或设置不正确,浏览器会报告此错误,表示未经授权无法获取相应内容。
请求出现网络错误 (Network Error)
当跨域请求在发送时出现网络错误(例如目标服务器不可访问、请求超时等),Axios 会捕捉这个错误,并将其报告为 "Network Error"。
预检请求失败 (Preflight request failed)
当使用 CORS 发起一些复杂的请求(例如带有自定义头信息或使用 PUT、DELETE 等非简朴请求类型),浏览器会在发送真实请求之前发送一个 OPTIONS 预检请求。如果服务器没有正确处理 OPTIONS 请求或未返回正确的预检相应头,浏览器会报告 "reflight request failed" 错误。
代理服务器错误
如果使用代理服务器作为办理方案,但代理服务器设置有误或不可用,Axios 大概会报告与代理服务器连接相干的错误。
Axios 跨域的办理方法



1. CORS

CORS 须要服务器设置 Access-Control-Allow-Origin 相应头,表示该资源可以被指定的域进行跨域访问。
  1. // 服务端代码
  2. res.setHeader('Access-Control-Allow-Origin', '*');
复制代码
2. 服务端启用 CORS

比如 Node.js  Express 启用 CORS:
  1. const express = require('express')
  2. const app = express()
  3. app.use(function (req, res, next) {
  4.   // 启用 CORS
  5.   res.header('Access-Control-Allow-Origin', '*');
  6.   next();  
  7. })
复制代码
3. JSONP

JSONP 的原理是动态插入
  1.     import axios from 'axios';
  2. axios.get('/api/user?callback=fetchUser');
  3. function fetchUser(user) {
  4.   console.log(user);
  5. }
复制代码
服务端返回 JSON 数据并带上函数调用:
  1.   fetchUser({
  2.   name: 'jack'
  3. })
复制代码
4. 代理服务器

在开辟情况下,可以在当地启动一个代理服务器,实现跨域访问。在下面的例子中,客户端可以通过访问代理服务器的 /api/data 路由来获取目标服务器上的数据。
  1.     // Node.js 代理服务器
  2. const express = require('express');
  3. const axios = require('axios');
  4. const app = express();
  5. const port = 3000;
  6. app.use(express.json());
  7. app.get('/api/data', async (req, res) => {
  8.   try {
  9.     const response = await axios.get('https://目标服务器的URL/data');
  10.     res.json(response.data);
  11.   } catch (error) {
  12.     res.status(500).json({ error: 'Failed to fetch data from the target server' });
  13.   }
  14. });
  15. app.listen(port, () => {
  16.   console.log(`Proxy server is running on http://localhost:${port}`);
  17. });
复制代码
Axios 跨域代码实例

假设存在一个须要跨域访问的 API:
  1.   
  2. axios.get('http://cross-domain-api.com/users')
复制代码
可以在当地 3000 端口启动一个 Express 代理服务器:
  1.     const express = require('express');
  2. const { createProxyMiddleware } = require('http-proxy-middleware');
  3. const app = express();
  4. app.use('/api', createProxyMiddleware({
  5.   target: 'http://cross-domain-api.com', // 跨域目标接口
  6.   changeOrigin: true
  7. }))
  8. app.listen(3000);
复制代码
然后修改 axios 请求地点,指向代理服务器即可:
  1. axios.get('http://localhost:3000/api/users')
复制代码
  1. ## 提示与注意事项
复制代码


  • 选择跨域办理方案时,思量到项目标复杂性和需求,选择最合适的方法。
  • JSONP 只支持 GET 请求,不适用于所有场景。
  • CORS 须要服务器端的支持,在一些旧版本的浏览器中大概不完全支持。
使用 Apifox 调试后端接口

Apifox = Postman + Swagger + Mock + JMeter,Apifox 支持调试 http(s)、WebSocket、Socket、gRPC、Dubbo 等协议的接口,并且集成了 IDEA 插件。在后端人员写完服务接口时,测试阶段可以通过 Apifox 来校验接口的正确性,图形化界面极大的方便了项目标上线服从。


总结

Axios 跨域常用的办理方法有 CORS、JSONP、代理等,开辟情况可通过代理服务器实现跨域,CORS 须要服务端设置 Access-Control-Allow-Origin 相应头,JSONP 只支持 GET 请求。选择恰当项目需求的办理方案能够很好地办理跨域题目,保障应用的正常运行。
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完备的备战堆栈,固然不是什么很值钱的东西,如果你用得到的话可以直接拿走:


这些资料,对于【软件测试】的朋友来说应该是最全面最完备的备战堆栈,这个堆栈也伴随上万个测试工程师们走过最困难的路程,盼望也能资助到你! 


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

小小小幸运

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表