使用html5Mode的角度路由在重新加载后给出"未找到"页面

jva*_*ler 4 javascript url-routing angularjs html5-history

我制作了一些Angular路线,如下面的代码所示.

app.config(function($routeProvider, $locationProvider, $provide) {
    $routeProvider
    .when('/', {
         templateUrl: 'home.html',
         controller: 'AppCtrl'
    });
    .when('/portfolio', {
        templateUrl: 'portfolio.html',
        controller: 'AppCtrl'
    })
    $provide.decorator('$sniffer', function($delegate) {
         $delegate.history = historyCompatCheck();
         return $delegate;
    });
    $locationProvider.html5Mode(true);
});
Run Code Online (Sandbox Code Playgroud)

这工作正常,在我将基础href设置为"/"后,它接受了一个带有"/ portfolio"的href的锚,但是当我转到" http://url.com/portfiolo "或尝试重新加载页面时当我在投资组合路线上时,它会给我一个服务器错误.我能为此做些什么吗?

提前致谢.

jva*_*ler 7

我自己解决了..你总是需要在项目的根目录中创建一个.htaccess文件.包含以下内容:

 <IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /
    RewriteRule ^index\.php$ - [L]
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule . /index.php [L]
 </IfModule>
Run Code Online (Sandbox Code Playgroud)

  • @Alberto为了更有帮助,我认为你需要在index.html或index.php的<head>中添加<base href ="/"> ;-) (2认同)