如何使用位置正则表达式通过nginx重定向/处理来自搜索引擎的请求

Rav*_*eja 5 server-configuration web-applications nginx

我开发了一个基于ajax的web应用程序,带有哈希爆炸网址.

我试图将请求从搜索引擎重定向到另一个生成HTML快照并发送响应的服务器.我试图在nginx中使用location指令实现这一点,如下所述:

      location ~ ^(/?_escaped_fragment_=).*$ {
         proxy_set_header        Host $host;
          proxy_set_header        X-Real-IP $remote_addr;
      proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_set_header        X-Forwarded-Proto $scheme;

          client_max_body_size    10m;
          client_body_buffer_size 128k;
          proxy_connect_timeout   60s;
          proxy_send_timeout      90s;
          proxy_read_timeout      90s;
          proxy_buffering         off;
          proxy_temp_file_write_size 64k;
          proxy_pass      http://x1.x2.x3.x4:8080;
          proxy_redirect      off;
      }
Run Code Online (Sandbox Code Playgroud)

但我无法让这个工作.有人可以纠正我正在使用的正则表达式(或)为我提供替代解决方案来实现这一目标.

提前致谢.

art*_*nig 5

您无法在位置名称(nginx docs)中检查参数:

请注意,所有类型的位置仅测试不带参数的请求行的URI部分.这样做是因为查询字符串中的参数可以通过多种方式给出,例如:

/index.php?user=john&page=1
/index.php?page=1&user=john

您可以在服务器部分(在此处找到)中设置重写规则:

if ($args ~ “_escaped_fragment_=(.+)”) {
    set $real_url $1;
    rewrite ^ /crawler$real_url;
}
Run Code Online (Sandbox Code Playgroud)

并定义一个"/ crawler"位置,可以将其重定向到HTML生成服务器.