nginx vue前后端分离配置示例

vue + thinkphp

vue为history路由模式,固定/api,/static前缀为php使用

server {
  listen 80;
  server_name localhost;

  set $static_root '';    # web目录
  set $php_root '';    # php目录
  root $static_root;

  index index.html index.htm index.php;

  location ~ \.php$ {
      root $php_root;
      fastcgi_pass   127.0.0.1:9000;
      fastcgi_index  index.php;
      fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
      include        fastcgi_params;
      fastcgi_buffer_size 128k;
      fastcgi_buffers 32 32k;
      fastcgi_connect_timeout 300;
      fastcgi_send_timeout 300;
      fastcgi_read_timeout 300;
  }

  location / {
      try_files $uri $uri/ /index.html;
  }
  
  location ^~ /api/ {
      root $php_root;
      if (!-e $request_filename) {
          rewrite  ^(.*)$  /index.php?s=/$1  last;
          break;
      }
  }

  location ^~ /static/ {
      root $php_root;
      access_log off;
  }

  # 首页不缓存
  location = /index.html {
      add_header Cache-Control no-cache;
      add_header Pragma no-cache;
      add_header Expires 0;
  }

  location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
      expires       12h;
      log_not_found off;
      access_log    off;
  }
}

vue + 端口转发

二级目录可使用此方法

server {
  listen 80;
  server_name localhost;
  root '';
  index index.html index.htm;

  location ^~ /api/ {
    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;
    proxy_pass http://localhost:8080;
    # proxy_pass http://localhost:8080/; #转发时想去除/api前缀可使用这条
  }

  location / {
      try_files $uri $uri/ /index.html;
  }

  # 首页不缓存
  location = /index.html {
      add_header Cache-Control no-cache;
      add_header Pragma no-cache;
      add_header Expires 0;
  }

  location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {
      expires       12h;
      log_not_found off;
      access_log    off;
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值