Docker nginx 配置单页面应用

发布于 2022-09-12 03:23:10 字数 1287 浏览 25 评论 0

我有一个单页面应用用Angular开发的,router采用的是history模式,我在本地想测试部署到nginx是否可以成功访问时遇到404问题,网上找了些资料说是需要设置try_files $uri $uri/ @router; 可是我试了还是不行,求大家帮忙看下,谢谢。

deploy nginx的脚本:

set -e;
docker rm -f my-nginx;
docker run --name my-nginx -d -p 80:80 \
-v /Desktop/my-nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /Desktop/my-nginx/log:/var/log/nginx \
-v /Desktop/my-nginx/html:/usr/share/nginx/html \
nginx

nginx的conf文件:

user  nginx;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

events {
    worker_connections  1024;
}

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    server {
        listen      80;

        location ^~ /test {
            try_files $uri $uri/ /test/index.html; 
        }
       
    }
    
    keepalive_timeout  65;
    include /etc/nginx/conf.d/*.conf;
}
我的应用文件全部放在test目录下,当访问`http://localhost/test`时正常,如果访问`http://localhost/test/myUrl` 就报404

2020/06/23 08:06:40 [error] 28#28: *10 open() "/usr/share/nginx/html/test/myUrl" failed (2: No such file or directory), client: 172.17.0.1, server: localhost, request: "GET /test/myUrl HTTP/1.1", host: "localhost"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

绮烟 2022-09-19 03:23:10

SPA 整这么复杂干啥?

照着改:

server {
    listen 80;
    location / {
        root /usr/share/nginx/html/test; # 这个是你入口文件所在的目录,如果不对就改
        index index.html index.htm;
        try_files $uri $uri/ /index.html =404; # index.html 是你的入口文件,如果不叫这个名,改
    }
    
    # 把你原来那第二个 location 删掉
}
玩套路吗 2022-09-19 03:23:10

先论证一下用history的必要性
如果没必要,就放弃history,所有问题就解决了
有几个用户会关心地址栏里的“#”
真想搞你系统的人,也不会因为没有“#”就没办法的
千万别自己骗自己

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文