我们提供了一些JSON Web API。用户可以在我们的网页上创建API密钥,然后使用该密钥作为HTTP头属性。但是,我们将允许在没有密钥的情况下访问试用。在这种情况下,我们如何设置nginx配置?
sample request
curl -H 'x-api-key:xxxx' https://api.xxx.com/xxx
字符串
我们需要同时设置(1)和(2)
(1) Without 'x-api-key' http header -> limit_req setting (e.g 10 request per sec)
(2) With 'x-api-key' http header -> no limitation.
型
更新1
这几乎是同一个问题。
Rate limit in nginx based on http header
2条答案
按热度按时间ttisahbt1#
我发现了这种方式,它的工作,但仍然不确定这个设置是不是理想的(看起来很奇怪…)。如果你能给予我任何建议,我将不胜感激。
字符串
vqlkdk9b2#
为了在Nginx中基于HTTP头设置速率限制,您可以使用$http_example_header变量。在你的情况下,你可以有这样的东西:
字符串