Nginx实际问题解决——如何指定地址访问指定页面

文章讲述了如何在Nginx配置中,针对localhost:8080/description路径,指定访问/var/www/dist/biographicalNotes/biographicalNotes.html。通过添加新的location块,使用alias指令映射路径并设置try_files以处理不同情况,同时启用静态文件的浏览器缓存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Nginx实际问题解决——如何指定地址访问指定页面

image.png

问题复现

/var/www/dist/biographicalNotes/下面有一个Html文件 biographicalNotes.html,我实际的nginx代理是这样的

server {
    listen 8080;
    server_name localhost;
    root /var/www/dist;
    index index.html;
    location / {
        try_files $uri $uri/ /index.html;
    }
    # Allow access to static resources
    location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ {
        expires max;
        add_header Cache-Control "public, max-age=31536000";
    }
​
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /var/www/dist;
    }
}

这段 Nginx 配置主要用于监听端口 8080,并且定义了一个基本的静态文件服务器。下面是对每个部分的解释:

  1. listen 8080;:指定 Nginx 监听在 8080 端口上。
  2. server_name localhost;:指定该服务器块的名称,此处是 localhost。
  3. root /var/www/dist;:指定网站的根目录,这里是 /var/www/dist。所有文件的路径都是相对于这个根目录的。
  4. index index.html;:定义默认的索引文件是 index.html。如果访问一个目录时没有指定文件名,默认会尝试加载 index.html
  5. location / { ... }:处理根路径 / 的请求。try_files $uri $uri/ /index.html; 表示尝试按照给定顺序查找文件,如果找不到,则返回 /index.html
  6. location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ { ... }:处理静态资源的请求,包括图片、CSS、JavaScript 和 SVG 文件。通过设置 expires max;add_header Cache-Control "public, max-age=31536000";,启用了浏览器缓存,提高页面加载速度。
  7. error_page 500 502 503 504 /50x.html;:定义错误页面的路径,当出现 500、502、503 或 504 错误时,会返回 /50x.html
  8. location = /50x.html { ... }:处理 /50x.html 的请求,返回这个错误页面。

但是我现在我要求 localhost:8080/description要去访问这个页面 /var/www/dist/biographicalNotes/biographicalNotes.html,现在又该如何去解决呢?

问题解决

server {
    listen 8080;
    server_name localhost;
​
    root /var/www/dist;
    index index.html;
​
    location / {
        try_files $uri $uri/ /index.html;
    }
​
    location /description/ {
        alias /var/www/dist/biographicalNotes/;
        try_files $uri $uri/ /biographicalNotes.html;
​
        location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ {
            expires max;
            add_header Cache-Control "public, max-age=31536000";
        }
    }
​
    # Allow access to static resources
    location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ {
        expires max;
        add_header Cache-Control "public, max-age=31536000";
    }
​
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /var/www/dist;
    }
}

于是我们里面加了一段,这段配置主要是用于处理访问路径以 /description/ 开头的请求。让我们逐步解释这个配置块:

location /description/ {
    alias /var/www/dist/biographicalNotes/;
    try_files $uri $uri/ /biographicalNotes.html;
​
    location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ {
        expires max;
        add_header Cache-Control "public, max-age=31536000";
    }
}
  1. location /description/ { ... }:

    • 这是一个 Nginx location 块,指定了路径匹配规则,即处理以 /description/ 开头的请求。
  2. alias /var/www/dist/biographicalNotes/;:

    • 使用 alias 指令指定了实际文件系统路径,将请求映射到 /var/www/dist/biographicalNotes/ 目录。这意味着访问 /description/ 将被映射到 /var/www/dist/biographicalNotes/
  3. try_files $uri $uri/ /biographicalNotes.html;:

    • try_files 指令用于尝试查找文件,按照给定的顺序查找,如果找不到,则按照最后一个参数的路径返回。
    • $uri 表示当前请求的 URI。
    • $uri/ 表示尝试查找目录,例如,如果请求是 /description/something/,则尝试查找 /var/www/dist/biographicalNotes/something/ 目录。
    • /biographicalNotes.html 是最后一个备用路径,如果前面的尝试都失败,则返回此文件。
  4. location ~* .(jpg|jpeg|png|gif|ico|css|js|svg)$ { ... }:

    • 嵌套的 location 块,用于处理特定类型的静态文件,包括图片、CSS、JavaScript 和 SVG 文件。
    • ~* 表示对后面的正则表达式进行不区分大小写的匹配。
    • .(jpg|jpeg|png|gif|ico|css|js|svg)$ 匹配以这些扩展名结尾的文件。
    • expires max; 设置浏览器缓存过期时间为最大值。
    • add_header Cache-Control "public, max-age=31536000"; 设置缓存控制头,使浏览器可以缓存这些静态资源。

总体而言,这段配置的目的是处理 /description/ 路径的请求,将其映射到指定的文件系统目录,并对其中的静态文件启用浏览器缓存。

### Nginx 正向代理解决前后端跨域问题 要通过 Nginx 实现正向代理来解决前后端跨域问题,可以通过配置 `proxy_pass` 和设置合适的 HTTP 头部字段完成。以下是详细的配置方法: #### 配置文件示例 以下是一个典型的 Nginx 配置文件片段,用于实现正向代理并解决跨域问题。 ```nginx http { server { listen 80; server_name localhost; # 设置允许的跨域头信息 add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS'; add_header Access-Control-Allow-Headers 'Origin, X-Requested-With, Content-Type, Accept'; location /api/ { # 将请求转发到目标服务器 proxy_pass http://backend-server:8080/api/; # 转发原始主机名给后端服务 proxy_set_header Host $host; # 转发真实 IP 地址 proxy_set_header X-Real-IP $remote_addr; # 转发协议和端口号 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } # 如果需要支持 WebSocket 协议,则需额外配置 location /ws/ { proxy_pass http://websocket-backend:8081/ws/; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } } } ``` 上述配置中: - 使用了 `add_header` 来指定 CORS 的响应头部,从而让浏览器能够接受来自其他源的请求[^2]。 - `proxy_pass` 定义了实际的目标地址,这里假设后端 API 运行在 `http://backend-server:8080/api/` 上[^3]。 - 添加了一些常见的代理头信息(如 `$host`, `$remote_addr`),以便后端能获取真实的客户端信息[^4]。 #### 解决跨域的核心机制 跨域问题是由于浏览器的安全策略——同源策略引起的。当发起 AJAX 请求时,如果目标 URL 不属于当前页面所在的源(即协议、域名或端口不一致),浏览器会阻止该请求。 Nginx 可以作为中间层,在接收到前端发出的请求后将其转发至真正的后端服务,并返回结果给前端。这样做的好处在于,对于浏览器而言,所有的请求都像是针对同一台服务器发出的,因此不会触发跨域限制[^1]。 --- ### 注意事项 1. **CORS 响应头**:确保设置了正确的 `Access-Control-*` 系列头部,否则即使成功代理也可能因缺少权限被拒绝访问。 2. **安全性考量**:生产环境中不应随意开放 `Access-Control-Allow-Origin` 为通配符 (`*`) ,建议限定具体的白名单域名。 3. **WebSocket 支持**:如果有实时通信需求,请记得启用升级握手逻辑(见 `/ws/` 部分)。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IT小辉同学

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

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

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

打赏作者

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

抵扣说明:

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

余额充值