nginx上历史模式的Vue路由器服务器配置不起作用

时间:2016-04-05 02:58:54

标签: laravel nginx laravel-routing vue.js vue-router

我从vue router documentation

阅读了以下说明
  

注意:使用历史记录模式时,需要正确配置服务器,以便用户直接访问您网站上的深层链接   没有得到404。

所以,我尝试配置我的nginx,如下所示

server {
    listen 80 default_server;
    listen [::]:80 default_server ipv6only=on;

    root /var/www/laravel/public/;
    index index.php index.html index.htm;

    server_name working.dev;

    location /user {
        rewrite ^(.+)$ /index.php last;

    }

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

    location ~ \.php$ {
        try_files $uri /index.php =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

以下是我的Vue配置

var router = new VueRouter({
    hashbang: false,
    history: true,
    linkActiveClass: "active",
    root:  '/user'
});

但是,当用户直接访问我网站中的深层链接时,我仍然得到404。

已编辑:我也使用Laravel路由。以下是我的laravel路由。

Route::get('user', function() {
    return View::make('user.index');
});

1 个答案:

答案 0 :(得分:3)

我刚看完mattstauffer blog post,终于找到了在Laravel路线上的方法。如下所示

String[] lines = Files.readAllLines(Paths.get("myfile.txt"));

当用户直接访问网站的深层链接时,它不会返回404.