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

php做网站浏览量做网站能收多少广告费

php做网站浏览量,做网站能收多少广告费,渭南网站建设服务,有没有可以做兼职的网站吗文章目录 一、前言二、问题场景三、开发环境配置(Vite)四、生产环境配置(Nginx)4.1 初始错误配置4.2 正确配置方案4.3 配置解析4.4高级配置选项 五、常见问题排查六、开发环境 vs 生产环境对比七、总结 一、前言 在前后端分离架构…

文章目录

  • 一、前言
  • 二、问题场景
  • 三、开发环境配置(Vite)
  • 四、生产环境配置(Nginx)
    • 4.1 初始错误配置
    • 4.2 正确配置方案
    • 4.3 配置解析
    • 4.4高级配置选项
  • 五、常见问题排查
  • 六、开发环境 vs 生产环境对比
  • 七、总结


在这里插入图片描述

一、前言

在前后端分离架构中,前端访问后端资源(尤其是图片、文件等静态资源)的反向代理配置是一个常见且容易踩坑的问题。最近在开发一个 Vue3 + .NET8 的项目时,我就遇到了开发环境配置正常,但部署到生产环境后图片无法访问的问题。本文将详细记录这个问题的解决过程,并给出开发环境和生产环境的完整代理配置方案。

二、问题场景

  • 前端:Vue3 项目,运行在 80 端口
  • 后端:.NET8 WebAPI,运行在 5005 端口
  • 需求:前端通过 http://domain.com/upload/xxx.jpg 访问后端 http://domain.com:5005/upload/xxx.jpg 的图片资源

开发环境下使用 Vite 的代理配置工作正常,但部署到生产环境后出现 404 错误。

三、开发环境配置(Vite)

vite.config.ts 中的配置如下:

export default defineConfig({server: {proxy: {'^/[Uu]pload': {target: 'http://localhost:5005',changeOrigin: true,}}}
})

这个配置实现了:

  1. 匹配所有以 /upload/Upload 开头的请求
  2. 转发到后端服务 http://localhost:5005
  3. changeOrigin: true 处理跨域问题

四、生产环境配置(Nginx)

4.1 初始错误配置

我最初尝试的 Nginx 配置:

location /upload {proxy_pass http://localhost:5005/upload;
}

这个配置会导致路径重复拼接,访问 http://domain.com/upload/xxx.jpg 实际会转发到 http://localhost:5005/upload/upload/xxx.jpg,显然不正确。

4.2 正确配置方案

经过研究和实践,正确的 Nginx 配置应该是:

server {listen 80;server_name domain.com;# 前端静态资源location / {root /usr/share/nginx/html;index index.html;try_files $uri $uri/ /index.html;}# 代理上传文件请求location ~* ^/upload {proxy_pass http://localhost:5005;proxy_set_header Host $host;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;}
}

4.3 配置解析

  1. location ~* ^/upload
    • ~* 表示不区分大小写的正则匹配
    • 匹配所有 /upload/Upload 开头的请求
  2. proxy_pass
    • 直接指向后端地址,不加 /upload 后缀
    • 这样会保留原始请求路径
  3. proxy_set_header
    • 传递必要的请求头信息
    • 确保后端能获取到真实的客户端信息

4.4高级配置选项

  1. 路径重写
    如果后端接口路径与前端的路径不一致,可以使用 rewrite 规则:
location ~* ^/upload {rewrite ^/upload/(.*) /api/upload/$1 break;proxy_pass http://localhost:5005;
}
  1. 负载均衡
    如果后端有多台服务器:
upstream backend {server 192.168.1.101:5005;server 192.168.1.102:5005;
}location ~* ^/upload {proxy_pass http://backend;
}
  1. 静态资源缓存
    对图片等静态资源启用缓存:
location ~* ^/upload {proxy_pass http://localhost:5005;proxy_cache my_cache;proxy_cache_valid 200 304 1h;proxy_cache_key "$scheme$request_uri";
}

五、常见问题排查

  1. 404 Not Found
  • 检查后端服务是否真的存在该文件
  • 确认 Nginx 的转发路径是否正确
  • 查看 Nginx 错误日志:tail -f /var/log/nginx/error.log
  1. 权限问题
    确保 Nginx 有权限访问后端服务:
chmod -R 755 /path/to/upload
chown -R www-data:www-data /path/to/upload
  1. 缓存问题
    强制刷新浏览器缓存:Ctrl + F5

六、开发环境 vs 生产环境对比

功能 开发环境(Vite)生产环境(Nginx)
匹配规则^/[Uu]pload(正则)
目标地址env.VITE_API_URL
路径修改自动
跨域处理changeOrigin: true
性能优化

七、总结

通过本文的配置,我们实现了:

  1. 开发环境和生产环境一致的代理行为
  2. 不区分大小写的路径匹配
  3. 完整的请求头传递
  4. 灵活的路径重写能力

关键点在于理解 Nginxproxy_pass 行为:

  • proxy_pass 包含 URI 时,会替换 location 匹配的部分
  • proxy_pass 不包含 URI 时,会保留原始请求路径

希望这篇指南能帮助你顺利解决前后端分离项目中的反向代理问题。如果仍有疑问,欢迎在评论区留言讨论!

http://www.dtcms.com/wzjs/839981.html

相关文章:

  • 邯郸网站建设邯郸网站制作泰安人才网网上办事
  • 做网站需要有公司吗下载app登录
  • 视频变成网站怎么做seo优化前景
  • 做的网站图片模糊网站建设投标文档
  • 求人做网站php后台网站开发
  • 如何判断网站是不是自适应影响网站速度的因素
  • 昆明优化网站排名女性开源网站
  • 商城网站商家入驻功能企业seo可以达到怎样的效果
  • 信誉好的高密网站建设wordpress更新方法
  • 网站建设要些什么做旅行的网站
  • 请将已备案网站接入访问百度账号登录官网
  • 萍乡网站建设萍乡网站备案与不备案的区别
  • 网站空间500m是什么意思王烨简历
  • phpstudy搭建网站教程wordpress顶部颜色改哪
  • 国内做的好网站有哪些seo怎么学
  • 个人房屋做民宿在哪个网站设计说明万能模板500字
  • 旅游网站首页制作没有内容的网站应该怎么做
  • 绵阳市网站建设在线视频
  • 汕头市企业网站建设教程贸易网站有哪些
  • 移动 网站模板旅游网站排名排行榜
  • 广西建设网站产品开发过程流程图
  • 潜江市住房城乡建设厅网站wordpress内页无法打开
  • 品牌网站建设小蝌蚪1a网站建设 长沙开福区
  • 网站如何添加统计代码微信商城开发需要多少钱
  • 住房和城乡建设部网站进不去宿迁东岸网络技术有限公司
  • 个人域名备案网站名称例子wordpress 大神
  • 房产网站建设整体架构瑞安企业网站建设
  • 网站开发如何模块化把网站做成微信小程序
  • 免费域名模板建站网络运维工程师自学
  • 网站域名注册规则做一个学校网站怎么做