什么是跨域 - 如何解决请求跨域问题(前端和后端)

系列文章目录

Tips:写Vue项目写的多了,一直使用的是代理服务器进行跨域。今天在回顾node的时候,又重新总结了一下后端解决浏览器跨域的方法



一、什么是跨域?

1.浏览器的跨域和同源策略介绍

跨域,指的是浏览器不能执行其他网站的脚本。 跨域是由浏览器的同源策略造成的,是浏览器施加的安全限制。

同源策略是指,协议 , 域名,端口有一个不相同就会触发同源策略,出现跨域问题。 请注意:localhost和127.0.0.1虽然都指向本机,但也属于跨域。
浏览器执行javascript脚本时,会检查这个脚本属于哪个页面,如果不是同源页面,就不会被执行。

2.火狐中的出现跨域(如下图)

在这里插入图片描述

3.谷歌中的出现跨域(如下图)

在这里插入图片描述


二、Vue代理服务器解决请求跨域

Vue跨域的解决方法点这儿 👉 代理服务器解决跨域


三、工具解决跨域

1.使用CORS Everywhere工具进行跨域

Tips:此工具具有一定的局限性,我们需要使用 火狐浏览器安装CORS Everywhere ,但是超级方便!!!!


四、Node解决跨域问题

1.使用cors解决跨域(暂时3种方法,还会更新的)

切记:这里安装不要安装成 cros 我刚开始就安装错了(cors和cros这俩兄弟长的很像,主要是记错了)

安装 :npm i cors -S

//第一种跨域方法:导入cros  
 var cors =require('cors')
 app.use(cors())

2.设置Access-Control-Allow-Origin解决跨域(单一接口)

 //第二种跨域方法:设置相应头
    res.setHeader("Access-Control-Allow-Origin", "*")

3.配置中间件解决跨域(全局)

//第三种跨域方案
 app.use((req,res,next)=>{
  res.setHeader("Access-Control-Allow-Origin", "*")
   next()
 })

4.Node解决跨域的完整代码(如下)

1.Node代码

//导入express
var express =require('express')
//注册app 

const app =express()
//静态文件夹注册
// app.use(express.static("www"))

//第一种跨域方法:导入cros  
// var cors =require('cors')
// app.use(cors())


//第二种跨域方案
// app.use((req,res,next)=>{
//   res.setHeader("Access-Control-Allow-Origin", "*")
//   next()
// })

app.get("/lo",(req,res)=>{
    //第三种跨域方法:设置相应头
    res.setHeader("Access-Control-Allow-Origin", "*")
    res.send("<h1>1231313</h1>")
})
app.get("/low",(req,res)=>{
    res.send("<h1>188999798789789</h1>")
})

app.listen(3000,()=>{
    console.log("Serve Is Running !!!");
})

2.Html的代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div>Text</div>
</body>
<script>
   fetch('http://localhost:3000/lo').then(res=>{
       console.log(res);
   })
   fetch('http://localhost:3000/low').then(res=>{
       console.log(res);
   })
</script>
</html>

五、HTML标签或Jquery解决跨域(jsonp跨域)

这种跨域写法基本早就被淘汰了,也不推荐使用,如果想要了解的话,可以点下面的链接⬇️

介绍jsonp跨域请求的link

这里主要的原理是 HTML标签中的src和href属性,不会出现跨域

 <a></a><script></script> 

总结

总之:文章中介绍了多种可以解决跨域的解决方案,后续还会继续更新在React中的代理服务器解决跨域请求,谢谢大家可以耐心的看完🙏🙏。祝大家技术越来越厉害!!!!!!🐮🐮🐮

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
跨域是指在浏览器中,一个网页的脚本试图去访问另一个网页的内容时,由于安全策略的限制而出现的问题。当脚本试图访问同一域名下的资源时,这是被允许的,但是当脚本试图访问不同域名下的资源时,就会触发跨域问题跨域问题是由于浏览器的同源策略导致的。同源策略是一种安全策略,它规定了浏览器只允许在同一域名下的网页之间进行相互通信,而不允许在不同域名下的网页之间进行相互通信。 跨域问题可以通过使用以下方法来解决: 1. JSONP(JSON with Padding):JSONP是一种利用script标签进行跨域请求的方法。利用这种方法,我们可以在页面中插入一个script标签,该标签的src属性指向一个API接口,API接口返回的数据会被包裹在一个函数调用中,并作为参数传递给该函数。 2. CORS(Cross-Origin Resource Sharing):CORS是一种跨域资源共享的机制。它允许浏览器向跨域的服务器发出XMLHttpRequest请求,从而实现跨域通信。 3. 代理服务器:代理服务器是一种位于客户端和目标服务器之间的中间服务器。当客户端需要访问跨域的资源时,它可以向代理服务器发出请求,代理服务器再将请求转发给目标服务器。由于代理服务器和目标服务器在同一域名下,因此不存在跨域问题。 以上三种方法各有优缺点,开发者可以根据具体需求选择合适的方法来解决跨域问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

满脑子技术的前端工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值