我开发了一个基于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;
}
但我无法让这个工作.有人可以纠正我正在使用的正则表达式(或)为我提供替代解决方案来实现这一目标.
提前致谢.
解决方法:
您无法检查位置名称(nginx docs)中的参数:
Note that locations of all types test only a URI part of request line without arguments. This is done because arguments in the query string may be given in several ways, for example:
您可以在服务器部分(找到here)中设置重写规则:
if ($args ~ “_escaped_fragment_=(.+)”) {
set $real_url $1;
rewrite ^ /crawler$real_url;
}
并定义一个“/ crawler”位置,可以将其重定向到HTML生成服务器.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。