javascript - 在 nginx 中使用带代理的预渲染

标签 javascript angularjs node.js nginx prerender

我正在尝试使用 prerender.io获取 angularjs 页面的快照。目前我有一个用于 Web 应用程序的 NodeJS 实例,并且 nginx 反向代理将请求从端口 80 重定向到 4000

根据 prerender nginx 手册 (https://gist.github.com/thoop/8165802) 我可以将搜索引擎机器人请求转发到 prerender url,但是因为我已经有 NodeJS 应用程序的代理,我不知道如何预渲染 try_files 指令。

我的问题是,如何同时使用 NodeJS 应用程序代理和 prerender 指令?

最佳答案

我相信 prerender example有答案。如果 prerender 设置为 1,它使用 rewrite 然后 proxy_pass。

所以你会改变这个:

if ($prerender = 0) {
            rewrite .* /index.html break;
        }

到这里:

if ($prerender = 0) {
        rewrite .* /index.html break;
        proxy_pass http://[INTERNAL IP]:[PORT];
    }

由于您使用的是 Node 并且不需要为静态文件设置一些东西,因此我会做进一步的修改。

这是我的最终答案:

server {
   listen 80;
   server_name example.com;

   location / {
       try_files $uri @prerender;
   }

location @prerender {
    #proxy_set_header X-Prerender-Token YOUR_TOKEN;

    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) {
        proxy_pass http://[INTERNAL IP]:[PORT];
    }
}
} 

我希望这会有所帮助。我要补充的一件事是我不会使用预渲染引擎。蜘蛛甚至可以索引使用 javascript 和 PDF 的链接和页面。

只要我的两分钱。

关于javascript - 在 nginx 中使用带代理的预渲染,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28792993/

相关文章:

javascript - 在 HTML5 和 JavaScript 中循环访问 localStorage

javascript - 数据未从 AngularJS Controller 传递到 NodeJS 服务器

Angularjs promise 在 1.2 中不绑定(bind)到模板

javascript - 错误lib sprintf nodejs restify mysql

javascript - 如何使 Material UI 模态和对话框可滚动?

javascript - 并发 AJAX 请求不起作用。最新的请求会覆盖之前的请求

javascript - Web 应用程序有意义的目录结构

node.js - 带有 socket.io 的 EC2

javascript - react 等待服务器响应

javascript - TypeError:未定义不是函数 - Sails.js