AngularJS html5Mode 的 Lumen 导致重新加载问题
Lumen with AngularJS html5Mode causes reload issue
我们有一个带有 AngularJS 前端的 Lumen 应用程序。我们正在使用前端路由,我们通过将 html5Mode 设置为 true 来删除 url 中的主题标签。
问题是,当我们尝试重新加载页面或键入不带主题标签的地址时,出现错误:
NotFoundHttpException in Application.php line 1244
在我们的 nginx 配置文件中,我们有这一行(我们使用 prerender.io 来缓存我们的页面以进行 SEO):
location / {
try_files $uri $uri/ /index.php?$query_string @prerender;
@prerender 看起来像这样(我删除了 prerender.io 提供的令牌):
location @prerender {
proxy_set_header X-Prerender-Token MY-TOKEN-IS-HERE;
set $prerender 0;
if ($http_user_agent ~* "baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") {
set $prerender 1;
}
if ($args ~ "_escaped_fragment_") {
set $prerender 1;
}
if ($http_user_agent ~ "Prerender") {
set $prerender 0;
}
if ($uri ~ "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent|ttf|woff)") {
set $prerender 0;
}
#resolve using Google's DNS server to force DNS resolution and prevent caching of IPs
resolver 8.8.8.8;
if ($prerender = 1) {
#setting prerender as a variable forces DNS resolution since nginx caches IPs and doesnt play well with load balancing
set $prerender "service.prerender.io";
rewrite .* /$scheme://$host$request_uri? break;
proxy_pass http://$prerender;
}
if ($prerender = 0) {
rewrite .* /index.html break;
}
}
注意:最后一个 if 表示“/index.html”。我已经用“/index.php”试过了。当我这样做时发生的是 index.php 文件只是被客户端下载,就好像它是一个下载文件一样。
如果您能帮助解决重新加载问题,我们将不胜感激。如果您需要任何其他信息,请告诉我。
我从这个问题中得到了答案:
Laravel 5 + AngularJS html5Mode
问题是针对 Laravel 的,但如果稍作更改,答案适用于 Lumen。
上面答案中的 Laravel 路由如下所示:
Route::get('/', function () {
return View::make('index');
});
Route::get('{all}', function () {
return View::make('index');
});
虽然我的流明路线是这样的:
$app->get('/', 'AppController@index');
$app->get('{all}', 'AppController@index');
显然,如果您不想,则不必进入控制器,但这就是我的设置方式。
我们有一个带有 AngularJS 前端的 Lumen 应用程序。我们正在使用前端路由,我们通过将 html5Mode 设置为 true 来删除 url 中的主题标签。
问题是,当我们尝试重新加载页面或键入不带主题标签的地址时,出现错误:
NotFoundHttpException in Application.php line 1244
在我们的 nginx 配置文件中,我们有这一行(我们使用 prerender.io 来缓存我们的页面以进行 SEO):
location / {
try_files $uri $uri/ /index.php?$query_string @prerender;
@prerender 看起来像这样(我删除了 prerender.io 提供的令牌):
location @prerender {
proxy_set_header X-Prerender-Token MY-TOKEN-IS-HERE;
set $prerender 0;
if ($http_user_agent ~* "baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") {
set $prerender 1;
}
if ($args ~ "_escaped_fragment_") {
set $prerender 1;
}
if ($http_user_agent ~ "Prerender") {
set $prerender 0;
}
if ($uri ~ "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent|ttf|woff)") {
set $prerender 0;
}
#resolve using Google's DNS server to force DNS resolution and prevent caching of IPs
resolver 8.8.8.8;
if ($prerender = 1) {
#setting prerender as a variable forces DNS resolution since nginx caches IPs and doesnt play well with load balancing
set $prerender "service.prerender.io";
rewrite .* /$scheme://$host$request_uri? break;
proxy_pass http://$prerender;
}
if ($prerender = 0) {
rewrite .* /index.html break;
}
}
注意:最后一个 if 表示“/index.html”。我已经用“/index.php”试过了。当我这样做时发生的是 index.php 文件只是被客户端下载,就好像它是一个下载文件一样。
如果您能帮助解决重新加载问题,我们将不胜感激。如果您需要任何其他信息,请告诉我。
我从这个问题中得到了答案: Laravel 5 + AngularJS html5Mode
问题是针对 Laravel 的,但如果稍作更改,答案适用于 Lumen。
上面答案中的 Laravel 路由如下所示:
Route::get('/', function () {
return View::make('index');
});
Route::get('{all}', function () {
return View::make('index');
});
虽然我的流明路线是这样的:
$app->get('/', 'AppController@index');
$app->get('{all}', 'AppController@index');
显然,如果您不想,则不必进入控制器,但这就是我的设置方式。