我正在尝试从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)
当您在开发模式下运行前端时,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的类名 第二步:将需要