利用nginx 反向代理解决跨域问题

news2024/11/25 2:58:44

 说到nginx,不得不说真的很强大,也带来很多便利用于解决一些头疼的难题。  

  一般来说可以用来做:静态页面的服务器、静态文件缓存服务器、网站反向代理、负载均衡服务器等等,而且实现这一切,基本只需要改改那万能的配置文件即可。

之前的博文记录了作为负载均衡。这里先记录一下作为静态页面的服务器和反向代理跨域的使用。

结合之前 《angularjs+webapi2 跨域Basic 认证授权》的案例,对跨域的方式进行改造一下。

一.静态页面服务器

nginx.conf 的配置(其实默认的也是如此,所以作为静态服务器只需要将静态文件移动到nginx下的html文件夹里就可以了)

server {
      listen       8094; #监听端口
      server_name  localhost; #

      #charset koi8-r;

      #access_log  logs/host.access.log  main;

     location / {
          root   html;#文件根目录
          index  index.html index.htm;#默认起始页
      }

   }

 然后打开浏览器 输入 localhost:8094 即可

就是这么简单

 

二.反向代理服务器-》跨域

之前我们跨域是借助了浏览器对 Access-Control-Allow-Origin 的支持。但有些浏览器是不支持的,所以这并非是最佳方案

现在我们来利用nginx 通过反向代理 满足浏览器的同源策略实现跨域

首先,我先注释掉之前的跨域设置

 

 

然后访问一下index1.html

 

提示了跨域问题

然后我们回到nginx.conf 配置一个反向代理路径(新增红色部分)

server {
        listen       8094;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

       location / {
            root   html;
            index  index.html index.htm;
        }
        location /apis {
    rewrite  ^.+apis/?(.*)$ /$1 break;
    include  uwsgi_params;
       proxy_pass   http://localhost:1894;
       }
}

配置说明:配置一个/apis  重写到我们真正的api地址http://localhost:1894  形成一个代理的过程。然后更改一下index1.html的api请求地址

这样这个api的地址就跟当前页面index1.html处于同源位置了。就是我们配置的nginx监听地址 localhost:8094

然后我们再次在浏览器中访问 index1.html   可能请求到的知识缓存页面 请清除缓存或重启nginx

没有了跨域问题。 这里因为我之前登陆过 并记录了 token 所以没有提示登录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/144079.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端插件的应用

像这种页面四个页面下面的展示格式都一样&#xff0c;这个时候就把公共部分代码抽取出来作为组件使用 直接把中间部分代码赋值过来 <template> <div> <div v-for"(items, index) in ford" :key"index"> <div v-if"items.shopC…

P3- 傅里叶变换1-通讯原理

前言&#xff1a;傅里叶变换是Modulation, OFDM 技术的理论基础这里主要介绍连续性随机变量的傅里叶变换,以及对应的性质。https://zhuanlan.zhihu.com/p/339281545https://wenku.baidu.com/view/ab338e55a16925c52cc58bd63186bceb19e8ede4.html?_wkts_1672887094135https://w…

pdf如何防止被他人编辑

好多人一直在寻找研究如何编辑或者修改PDF文件&#xff0c;有需求就会有市场&#xff0c;现在市场上或者网络上有非常多的PDF编辑软件&#xff0c;可以编辑修改PDF文件中的内容。即使PDF文件加了密码保护&#xff0c;我们大部分人依然可以轻易的通过在浏览器中虚拟打印的方式&a…

2023.1.6 学习总结

1.set容器的相关函数 set&#xff0c;顾名思义是“集合”的意思&#xff0c;在set中元素都是唯一的&#xff0c;而且默认情况下会对元素自动进行升序排列。 set容器 包含头文件&#xff1a; #include<set> set中只能用insert函数实现数据的输入。 set<int> s…

32.深度学习模型优化加速方法-1

32.1 模型优化加速方法 模型优化加速能够提升网络的计算效率,具体包括: Op-level的快速算法:FFT Conv2d (7x7, 9x9), Winograd Conv2d (3x3, 5x5) 等;Layer-level的快速算法:Sparse-block net [1] 等;优化工具与库:TensorRT (Nvidia), Tensor Comprehension (Facebook) …

【代码题】栈的应用

目录 1.有效的括号 2.逆波兰表达式求值 1.有效的括号 点击进入该题 https://leetcode.cn/problems/valid-parentheses/description/ 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有…

【黑马】瑞吉外卖-Day01、02笔记

瑞吉外卖 数据库搭建 表结构 Maven项目 创建Maven项目 编写pom文件 编写配置文件application.yml 创建启动类ReggieApplication.java 前端静态资源的配置 将两个前端静态资源包导入到resource目录下方&#xff0c;由于Spring-MVC默认只能访问static和templete下面的文件…

04-GC的常见收集方法:标记清除、标记复制、标记整理算法、分代收集的原理与特点?

1.标记清除算法(Mark-Sweep) 最基础的垃圾回收算法&#xff0c;分为两个阶段&#xff0c;标记和清除。 1.标记阶段标记出所有需要回收的对象 2.清除阶段回收被标记的对象所占用的空间 缺点: 1.容易产生大量的内存碎片,后续可能发生大对象不能找到可利用空间的问题 2.标记和清…

【JavaGuide面试总结】Java基础篇·上

【JavaGuide面试总结】Java基础篇上1.JVM vs JDK vs JRE2.Java 和 C 的区别?3.Java 程序从源代码到运行的过程4.为什么说 Java 语言“编译与解释并存”&#xff1f;5.说说default关键字的几个用法6.静态变量有什么作用&#xff1f;7.字符型常量和字符串常量的区别?8.成员变量…

Verilog语法笔记(夏宇闻第三版)-运算符及表达式

目录 运算符按其功能可分为以下几类: 按其所带操作数的个数运算符可分为三种&#xff1a; 基本的算术运算符&#xff1a; 位运算符&#xff1a; 逻辑运算符&#xff1a; 关系运算符&#xff1a; 等式运算符&#xff1a; 移位运算符&#xff1a; 位拼接运算符(Concatati…

png如何转pdf?这几个方法快收藏起来

现如今&#xff0c;电脑上拥有的图片格式那么多&#xff0c;而每种格式分别都有自己的特点&#xff0c;就例如png格式。它是一种无损压缩算法的图片格式&#xff0c;能够保证在不失真的情况下&#xff0c;压缩图片文件大小。但在我们工作中&#xff0c;难免会需要将png图片转换…

字典树基础与应用

字典树&#xff08;Trie) 字典树&#xff08;Trie&#xff09;也叫前缀树&#xff0c;是一种针对字符串进行维护的树。 其中的键通常是字符串&#xff0c;由节点在树中的位置决定&#xff0c;键保存在边而不是在节点 一个节点的所有子孙具有相同的前缀&#xff0c;也就是这个…

PLGA-MAL/COOH/NH2基团封端聚(D,L-丙交酯-co-乙交酯)共聚物;可以用于制备胶束或者囊泡等新型靶向材料

1. HO-PLGA-Mal 马来酰亚胺封端聚&#xff08;D&#xff0c;L-丙交酯-co-乙交酯&#xff09;共聚物中文名称 马来酰亚胺封端聚&#xff08;D&#xff0c;L-丙交酯-co-乙交酯&#xff09;共聚物英文名称 HO-PLGA-Mal分子量&#xff1a;1000-100000之间选择 比例&#xff08;LA…

Golang UDP IPV6 编程

一、网络通信的步骤 服务端 1.socket() 创建通信的套接字socket:ip:addr 2.bind() 将套接字绑定监听的地址和端口号&#xff0c;作用是&#xff1a;服务器一般有很多网卡&#xff0c;多个IP地址&#xff0c;bind指定具体监听 哪一个IP地址及对应的端口号&#xff08;若服务…

消防应急物资智能仓储管理系统

一&#xff0c;项目背景消防应急物资装备管理系统(智装备 DW-S302)是一套成熟系统&#xff0c;依托互 3D 技术、云计算、大数据、RFID 技术、数据库技术、AI、视频分析技术对 RFID 智能仓库进行统管理、分析的信息化、智能化、规范化的系统。基于物联网技术&#xff0c;实现装备…

win10录屏快捷键是什么?录屏快捷键怎么设置

录屏是我们在学习和工作&#xff0c;经常会使用得到的工具。不管是录制网课视频&#xff0c;还是录制线上办公会议&#xff0c;都可以使用得上。在win10电脑系统中&#xff0c;就有录屏的功能&#xff0c;还自带了录屏快捷键。那win10录屏快捷键是什么&#xff1f;今天就给大家…

通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接

通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接 文章目录通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接SwitchyOmega的安装PAC脚本示例示例 1&#xff1a;如果主机是本地主机&#xff0c;则直接连接示例 2&#xff1a;如果主机在防火墙内部&#xff0c;则直接连…

华为云、阿里云、腾讯云、百度云、浪潮云、金山云-云计算能力横向对比

导读 近些年&#xff0c;各大公司和码农们对云服务需求日益增长&#xff0c;大家不断在问“做云服务和物联网服务器的到底哪家强&#xff1f;”。网上也有不少人给出简单的答案&#xff0c;“明显是腾讯云&#xff0c;华为云的应用还没那么广泛&#xff0c;目前最好的有三个&am…

SpringBoot统一功能处理实现

⭐️前言⭐️ 这篇文章主要介绍Spring Boot的统一功能处理模块&#xff0c;也是AOP的实战环节。 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主将持续更新学习记录收获&#xff0c;友友们有任何问题可以在评论…

ORB-SLAM2 --- KeyFrameDatabase::DetectLoopCandidates函数

目录 1.函数作用 2.函数流程 3.函数解析 3.1 传入参数解析 3.2 找出和当前帧具有公共单词的所有关键帧&#xff0c;不包括与当前帧连接的关键帧 3.3 统计上述所有闭环候选帧lKFsSharingWords中与当前帧具有共同单词最多的单词数&#xff0c;用来决定相对阈值 3.4 遍…