Nginx代理跨域

一、Nginx代理跨域配置

在开发中,由于浏览器同源策略的限制,会存在跨域问题。Nginx是一个高性能的Web服务器,它有着强大的代理功能,可以通过Nginx代理跨域来解决这个问题。

下面是配置示例:

location /api/ {
  proxy_pass http://example.com/;
  proxy_set_header Host $host;
  proxy_set_header Origin $host;
  proxy_set_header Referer $host;
}

其中,proxy_pass指定代理的目标地址,而proxy_set_header则设置一些头部信息。Origin和Referer是防止浏览器CSRF攻击的必要头部信息,需要加上。

二、Nginx配置代理解决跨域问题

可以通过修改Nginx配置文件来解决跨域问题。

下面是配置示例:

location / {
  add_header Access-Control-Allow-Origin *;
  add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";
  add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE';
  if ($request_method = 'OPTIONS') {
    return 204;
  }
}

其中,Access-Control-Allow-Origin指定允许跨域的域名,可以使用通配符*表示允许所有域名。Access-Control-Allow-Headers设置允许跨域的头部信息。Access-Control-Allow-Methods指定允许的请求方法。当请求方法为OPTIONS时,直接返回204,表示允许请求。

三、Nginx代理跨域/api

Nginx代理跨域/api通常用于代理RESTful API。

下面是配置示例:

location /api/ {
  proxy_pass http://example.com/;
  proxy_set_header Host $host;
  proxy_set_header Origin $host;
  proxy_set_header Referer $host;
}

四、Nginx代理数据库

在实际开发中,有时需要通过Nginx代理访问数据库。

下面是配置示例:

location / {
  proxy_pass http://localhost:3000/;
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection 'upgrade';

  proxy_set_header Host $host;
  proxy_cache_bypass $http_upgrade;
}

其中,proxy_pass指定代理的目标地址(此处为本地的3000端口)。proxy_http_version指定HTTP协议版本(1.1)。proxy_set_header Upgrade和proxy_set_header Connection是为了支持WebSocket。其他设置与前面相似。

五、Nginx代理跨越

除了代理跨域,Nginx还可以用来代理跨越。

下面是配置示例:

location / {
  if ($request_method = 'OPTIONS') {
    add_header 'Access-Control-Allow-Origin' '*';
    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
    #
    # Custom headers and headers various browsers *should* be OK with but aren't
    #
    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
  
    #
    # Tell client that this pre-flight info is valid for 20 days
    #
    add_header 'Access-Control-Max-Age' 1728000;
    add_header 'Content-Type' 'text/plain; charset=utf-8';
    add_header 'Content-Length' 0;
    return 204;
  }
  if ($request_method = 'POST') {
    add_header 'Access-Control-Allow-Origin' '*';
    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
    add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
  }
  if ($request_method = 'GET') {
    add_header 'Access-Control-Allow-Origin' '*';
    add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
    add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
    add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
  }
}

此处采用了常用的RESTful风格,并添加了Access-Control-Allow头部信息,允许跨域访问。

六、Nginx代理模式有哪些

Nginx支持多种代理模式,包括反向代理、负载均衡和高可用等。

反向代理:指的是将客户端请求转发到多个服务器上。

负载均衡:指的是将客户端请求平均地分配到多个服务器上,以提高系统吞吐量和性能。

高可用:指的是将多个服务器配置在一起,以保证在某个服务器故障时可以无缝地切换到其它可用的服务器上,以提供可靠的服务。

七、Nginx代理局域网yum

变相实现yum代理缓存。yum在局域网中的使用非常普遍。通过Nginx来代理yum,可以在本地镜像服务器上建立一个yum代理缓存。当客户端需要软件包时,可以从这个本地代理缓存中快速地获取。

下面是配置示例:

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=yum_cache:10m inactive=60m;
server {
  listen 80;
  server_name yum.localdemo.com;
  root /usr/share/nginx/html;
  
  location / {
    index index.html;
  }

  location /repos {
    proxy_pass http://repo.localdemo.com/;
    proxy_set_header Host $host;
    proxy_cache yum_cache;
    proxy_cache_valid 200 15m;
    proxy_cache_valid 404 1m;
    add_header X-Cache-Status $upstream_cache_status;
  }
}

其中,proxy_cache_path用于设置Nginx的缓存路径,方便快速地响应客户端请求。server_name指定本地镜像服务器的地址。location /repos指定缓存的yum软件包所在目录。

八、Nginx代理

Nginx作为高性能的Web服务器,在代理方面有着不可替代的优势。除了上面介绍的代理模式外,还可以通过反向代理来实现访问外部资源。

示例:

upstream backend {
  server 192.168.1.1 weight=10;
  server 192.168.1.2 weight=10;
}

server {
  listen 80;
  server_name frontend.localdemo.com;

  location / {
    root /usr/share/nginx/html/;
    try_files $uri /index.html;
  }

  location /api {
    proxy_pass http://backend;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
  }
}

其中,upstream backend定义了后端服务器的地址和权重。location /api指定了代理的目标地址,并设置了一些头部信息。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/219620.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-09 11:00
下一篇 2024-12-09 11:00

相关推荐

  • Java如何从Nginx下载文件

    本文将从以下几个方面详细介绍如何使用Java从Nginx下载文件。 一、准备工作 在Java中下载文件需要使用到Apache HttpClient库,这个库是一个基于Java的HT…

    编程 2025-04-27
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • NGINX权限被拒绝问题

    NGINX是一款常见的Web服务器软件,但是在使用中常会遇到“permission denied”权限被拒绝的问题。下文将从多个方面介绍本问题和解决方法。 一、系统权限问题 1、检…

    编程 2025-04-25
  • 关闭nginx命令详解

    一、linux系统中关闭nginx命令 1、使用ps命令找到nginx的进程ID $ ps -ef | grep nginx 2、发送信号给nginx进程结束 $ kill -QU…

    编程 2025-04-25
  • 深入浅出:理解nginx unknown directive

    一、概述 nginx是目前使用非常广泛的Web服务器之一,它可以运行在Linux、Windows等不同的操作系统平台上,支持高并发、高扩展性等特性。然而,在使用nginx时,有时候…

    编程 2025-04-24
  • nginx指定配置文件详解

    一、配置文件介绍 nginx的配置文件主要由指令和块组成,以“;”分号作为结束符号,以“{}”大括号作为块的开始和结束标志。 nginx的默认配置文件在安装目录下的conf文件夹中…

    编程 2025-04-24
  • 重启nginx服务的命令详解

    nginx是一个高性能的Web服务器,可通过重新启动nginx服务来更新配置文件和释放资源。本文将从多个方面详细阐述如何重启nginx服务,包括命令的使用、参数的说明等。 一、ng…

    编程 2025-04-24
  • Nginx$Host详解

    一、什么是Nginx$Host Nginx是一款轻量级的Web服务器,可以作为反向代理服务器、负载均衡服务器等。而Nginx$Host是Nginx中的一个特殊变量,它用于表示当前请…

    编程 2025-04-23
  • Mac Nginx详细介绍

    一、安装Nginx 安装nginx最简便的方法是使用Homebrew。执行以下命令来安装Homebrew: /usr/bin/ruby -e “$(curl -fsSL https…

    编程 2025-04-23
  • 如何解决Windows下Nginx启动一闪而过的问题

    一、Nginx 安装及配置过程 Nginx是一款轻量级的Web服务器,可以用于反向代理、负载均衡、缓存等方面的应用,常用于Web应用的高并发场景。在Windows系统上,安装ngi…

    编程 2025-04-23

发表回复

登录后才能评论