当前位置: 首页 > news >正文

Nginx 反向代理(解决跨域)

文章目录

  • 前言
  • 一、同源策略
  • 二、跨域是什么?
  • 三、Nginx解决跨域
    • 1.前端示例代码
    • 2.说明
  • 四、nginx反向代理配置
  • 五、启动nginx
  • 六、最终效果
  • 总结


前言

Nginx反向代理解决跨域

一、同源策略

  1. 定义:同源策略(Same-Origin Policy)是指浏览器限制一个源(origin)的文档或脚本如何与另一个源的资源进行交互的安全策略。源是由协议(如HTTP HTTPS)、域名(如example.com)和端口号(如80、443)组成的唯一标识。
  2. 原理:根据同源策略,如果两个资源的协议、域名和端口号完全相同,则它们被认为是同源的,可以相互访问和交互。否则,它们被认为是不同源的,浏览器会限制它们之间的交互,以防止恶意网站通过跨域请求获取用户的敏感信息或进行其他恶意操作。

二、跨域是什么?

‌‌跨域(Cross-Origin)是指在‌浏览器中,当前正在访问的页面的域名与请求的资源域名不一致的情况。‌ 例如,在A网站上通过AJAX请求B网站的数据时,就会产生跨域问题。‌跨域问题通常发生在前后端分离的应用中,当前端和后端部署在不同的域或端口上时,浏览器出于安全考虑会阻止跨域请求。跨域是由浏览器的‌同源策略造成的。

三、Nginx解决跨域

nginx通过反向代理解决跨域问题,本文是直接在nginx目录html操作的,完成这步你需要下载nginx :https://nginx.org/自行去官网下载

1.前端示例代码

在这里插入图片描述

代码如下(示例):

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1"><title></title></head><body><button id="btn">点击获取</button><script>btn.onclick = () => {let xhr = new XMLHttpRequest()console.log(222);// 注意:这里我们地址不要写后端完整地址:我们给前面加一个/api就行,把// 端口哪里删去xhr.open('GET', '/api/user/all')xhr.onreadystatechange = () => {if (xhr.readyState == 4 && xhr.status == 200) {console.log(JSON.parse(xhr.responseText))}}xhr.send()}</script></body></html>

2.说明

这是我后端服务器上的接口地址:端口号是在5000,而我前端页面是80端口,所以就会导致跨域问题

在这里插入图片描述

四、nginx反向代理配置

配置反向代理,这里的/api/一定要与前端请求接口地址一致。

location /api/ {proxy_pass http://127.0.0.1:5000/;
}

在这里插入图片描述

五、启动nginx

双击点击nginx.exe启动即可

在这里插入图片描述

在这里插入图片描述

六、最终效果

发现我们后端请求就成功了。
在这里插入图片描述

总结

综上所述,Nginx解决跨域问题的方法有很多,比如修改响应头、使用CORS模块。但你可以根据实际需求选择最适合的方法来解决跨域问题。

http://www.lryc.cn/news/476277.html

相关文章:

  • gRPC-4种通信模式
  • 第五项修炼—系统思考
  • PYNQ 框架 - VDMA驱动 - 帧缓存
  • Java导出Word文档的几种方法
  • OceanBase V4.3.3,首个面向实时分析场景的GA版本发布
  • Maven随笔
  • 牛客题目解析
  • AG32的3个ADC可以并联使用吗
  • 什么是 OpenTelemetry?
  • [vulnhub]DC:7
  • 个性化十足的贵族服务器,惠普ML310e Gen8,服务器中的 “潘多拉魔盒”
  • 百度社招内推
  • 本地部署开源在线即时通讯软件Fiora打造个人私密聊天室
  • TS(类 接口 泛型)
  • docker 启动 neo4j
  • OPENAI官方prompt文档解析
  • 【GESP】C++一级练习BCQM3092,双面打印
  • mysql--多表查询
  • RHCE-Web-nginx http实验和nginx https实验
  • 少儿编程学习现状洞察:青少年编程教育需求与学习频率分析
  • 接口集成、快速对接-阿里身份证实名认证接口
  • HTTP、WebSocket、gRPC 或 WebRTC:各种协议的区别
  • Unity3D学习FPS游戏(8)装弹和弹夹UI显示
  • Android 托管 Github Action 发布 Github Packages ,实现 Mvn 免费自动化托管
  • 火山引擎VeDI数据服务平台:在电商场景中,如何解决API编排问题?
  • 【每日C/C++问题】
  • layaair做帧动画,等待一秒之后移动坐标,坐标位置明明相同,执行的时候却会抖动。
  • SAP分包业务中能否应用后继物料?
  • 【数据结构】二叉树——判断是否为完全二叉树
  • FFmpeg 4.3 音视频-多路H265监控录放C++开发十. 多线程控制帧率。循环播放,QT connect 细节,