我已经努力理解 NginX 在位置订单处理中的逻辑,但它仍然超出了我的能力范围,我怀疑这就是我遇到以下问题的原因。
我运行一个 SugarCRM 实例,我已经用基本身份验证阻止了它。有一些文件,例如 ical_server.php 我想关闭基本身份验证,因此智能手机可以轻松访问这个订阅的日历,它已经拥有自己的基于令牌的安全性。
我在我的conf中有这个。但是 ical_server.php 被作为原始 php 下载,这表明它没有到达 fastcgi 解析器,即使 CRM 的其余部分工作得很好。
location /sugarcrm/ {
auth_basic "Username and Password are required";
auth_basic_user_file /var/web/webaddress.tld/private/.htpasswd;
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
location ~ \.php$ {
location ~ _server.php$ {
auth_basic "off";
}
try_files $uri =404;
fastcgi_pass 127.0.0.1:9000;
fastcgi_read_timeout 600;
fastcgi_send_timeout 600;
fastcgi_max_temp_file_size 0;
fastcgi_buffer_size 56k;
fastcgi_buffers 16 48k;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
如何实现这种选择性关闭基本身份验证?
由于我无法通过他的评论以正确的答案奖励 Alexey Ten,因此这里是工作配置:
因为,正如 Alexey 指出的那样,fastcgi 不会被继承,所以我必须再次将它放在 _server.php$ 位置。通过包含,它也可以很好地整理东西。现在 php 被很好地解析了。
(事实上,auth_basic 在该文件上完全关闭实际上并不是有意的,但这已在另一个问题中涵盖。只是提到它以防有人发现这个......)
再次感谢阿列克谢。