nginx iphone 为 angular 应用重写 - 刷新时获取 404

nginx iphone rewrite for angular app - getting 404 while refreshing

我们在 nginx 上为移动客户端托管了一个 angular 应用程序。 angular 代码负责所有路由。所以没有子目录等。所以路径作为参数传递给 angular 文件,即 "index_angular.html" 和 angular 负责其余部分。坐下工作并通过菜单项导航工作。但是一旦我进入一个菜单项然后刷新页面,它 returns 一个 404 错误。这是 nginx 配置文件:

server {
listen 80;
root /apps/angular;
server_name angular.com;

location / {
add_header 'Access-Control-Allow-Origin' 'http://angular.com';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET,POST,OPTIONS';
index  index.php;

if ($http_user_agent ~* '(iPhone|iPod|android|blackberry)') {

        rewrite ^/$ /index_angular.html last;

        }

}


location /menuitem1/ {
rewrite ^/(.*)$ /index_angular.html last;
}

我需要能够刷新页面并将所有路径参数发送到应该负责路由的 index_angular.html 文件。 请帮忙。

你需要在你的位置上配置404到returnindex_angular.html

location /menuitem1/ {
    try_files $uri $uri/ /index_angular.html =404;
}

这应该有用,让我知道。

这是一个对我有用的例子,如果我在你的情况下做错了:

server {
    listen 80 default_server;

    server_name myProject.lab;

    root /var/www/myProject;

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

}

更新

我签入了 nginx documentation,我想另一种选择是在错误页面的情况下定义重定向:

location /old/path.html {
    error_page 404 =301 http:/example.com/new/path.html;
}

但我总是使用我的第一个建议,而且效果很好:)