项目中多数使用react单页面开发,路由使用react-router的browser-router,这样页面访问路径看起来像是真实的,如http://xx.xxx.xxx/a/b。但当项目访问路径为多级时,直接输入地址或刷新会报404。这是由于服务器会将其当作真实的路径去请求页面,但实际这个页面是不存在的,因此会报404错误。解决方法是让其请求到项目入口页面,由js去处理路由加载响应模块。html
假如项目为A,入口文件为A/view/index.html,访问地址如 http://test.x431.com/A/view/login。在Nginx加以下配置。react
1 location ~* view { 2 rewrite (.+)/view/(.+)$ $1/view/index.html break; 3 }
参考文档:nginx
http://nphard.me/2016/03/07/nginx-for-react/服务器
http://www.cnblogs.com/feiyuanxing/p/4668818.htmlreact-router