当前位置: 首页 > 知识库问答 >
问题:

如果港口被隐藏,CORS问题与码头工人

金皓君
2023-03-14

我正在尝试从vue前端应用程序连接到Lumen后端api。但是我想在不暴露后端api端口的情况下这样做,所以这一切都将在内部处理。我想要这样做的原因是因为api的一些endpoint是公共的,目前作为一个小应用程序,我不想担心任何人从外部调用api。

对于后端api,我使用的是ngin x。

我已经添加了一个中间件,在Lumen中启用了CORS,在nginx中启用了CORS。

version: "3.7"
services:
  backend:
    build:
      context: ./docker/php-fpm
      dockerfile: Dockerfile
    container_name: ecommerce-backend
    restart: unless-stopped
    working_dir: /var/www/
    volumes:
      - ./backend:/var/www
    networks:
      - ecommerce

  frontend:
    build:
      context: ./docker/vue
      dockerfile: Dockerfile
    container_name: ecommerce-frontend
    command: npm run serve
    volumes:
      - ./frontend:/app
    ports:
      - 8081:8080
    networks:
      - ecommerce

  nginx:
    image: nginx:alpine
    container_name: ecommerce-nginx
    restart: unless-stopped
  #if uncomment ports it works
  #ports:
    #  - 8000:80
    volumes:
      - ./backend:/var/www
      - ./docker/nginx:/etc/nginx/conf.d/
    networks:
      - ecommerce

networks:
  ecommerce:
    driver: bridge

nginx.conf是这样的:

server {
    listen 80;
    index index.php index.html;
    error_log  /var/log/nginx/error.log;
    access_log /var/log/nginx/access.log;
    root /var/www/public;
    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass backend:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;

    }
    location / {
        try_files $uri $uri/ /index.php?$query_string;
        gzip_static on;

        add_header 'Access-Control-Allow-Origin' "*" always;
        add_header 'Access-Control-Allow-Credentials' 'true' always;
        add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS' always;
        add_header 'Access-Control-Allow-Headers' 'Accept,Authorization,Cache-Control,Content-Type,DNT,If-Modified-Since,Keep-Alive,Origin,User-Agent,X-Requested-With' always;


    }

}

我使用的CORS中间件如下:在Lumen中启用CORS(stack overflow)

共有1个答案

洪光霁
2023-03-14

当您在开发模式下运行前端时,vue.js开发服务器会返回CORS错误:

< code >命令:npm run serve

您可以通过使用vue-js配置中的proxy属性轻松解决这个问题。

module.exports = {
  devServer: {
    proxy: 'http://localhost:8000'
  }
}

在生产设置中,如果nginx服务也提供客户端捆绑包,则您的配置应该可以工作。

 类似资料:
  • 我的困惑是wile创建镜像主机端口在Dockerfile中被指定为8080,但当从同一个镜像主机端口运行容器时,被指定为3000。那么这个容器将在哪个主机端口运行,为什么?

  • 我正在与Django合作一个项目,该项目通过React前端上的Django Rest框架通过API提供数据。可浏览的API工作正常,但是,react前端在控制台中给出了一个错误。 我已成功安装django cors标头。 CORS策略阻止从http://127.0.0.1:8000/products/http://localhost:3000获取数据:请求的资源上不存在访问控制允许来源标头。如果不

  • 我正在构建一个应用程序,它会显示一个窗口,询问用户是否要使用两个按钮选项暂停计算机,其中一个是“是”,电脑将暂停。 另一个名为“稍后”的按钮应该隐藏窗口,一个小时后它再次出现,并提出相同的问题。 “后来的巴特顿”的代码 你在代码中看到的布尔是bc,这是我认为我可以控制的方式,相信我,我尝试了不同的方式,但没有人只是帮我解决这个问题,这是GUI类的代码 我知道那个平台。退出();终止程序,但当我只使

  • 我在过去几周开始使用Visual Studio Code(vscode),所以我对它还是新手。它有一些不错的功能,但也有一些陷阱和惊喜。现在,我想隐藏一个列,我们可以在其中导航正在编辑的当前源,在一种滚动条中,但具有代码缩略图外观。我截取了一个屏幕截图来向您展示我的意思。它以红色突出显示: https://imgbox.com/cMMS4rgJ 我搜索了菜单,测试了大部分菜单,但找不到这个。在实际

  • 我的expo go应用程序出错。 错误: 未捕获的错误:java.net.SocketTimeout异常:10000ms后无法从/192.168.100.2(端口39440)连接到/192.168.100.10(端口19000)。

  • 本文向大家介绍关于Layui Table隐藏列问题,包括了关于Layui Table隐藏列问题的使用技巧和注意事项,需要的朋友参考一下 layui没有提供Table隐藏列的功能(只是写这个文档的时候没有提供)。 第一步:获取Layui的TableBox Jquery对象 this._table_elem 是指的Table标签的ID layui-table-box 是layui的类名 第二步:将需要