授权 header 不与HTTP OPTIONS请求一起发送。我只想在请求为OPTIONS时禁用此身份验证,而将其保留用于其他请求。这是我目前拥有的相关配置代码。似乎看不出为什么它不起作用。我总是在OPTIONS请求中收到401未经授权的错误。
location ~ /foo/bar
{
if ($request_method = OPTIONS) {
set $auth_basic "off";
}
if ($request_method != OPTIONS)
{
set $auth_basic "Resctricted";
set $auth_basic_user_file /var/www/.htpasswd;
}
auth_basic $auth_basic;
auth_basic_user_file $auth_basic_user_file;
}
最佳答案
看来这是一篇旧文章,但找到了以下解决方案:
将以下配置放入“位置”中,然后从服务器中删除所有auth_basic。这会工作
location / {
# Your node proxy configuration for example #
# Make options requests work #
limit_except OPTIONS {
auth_basic "Restricted access zone";
auth_basic_user_file /etc/nginx/pass/protected;
}
}
关于nginx:仅在http请求为OPTIONS时才不需要基本身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44598417/