Nginx モジュール/private
を使用してディレクトリへのアクセスを許可したい。auth_request
Nginxのドキュメントでは、次のようにする必要があるようです:
server {
listen 80;
server_name localhost;
location /private/{
auth_request /auth;
}
location /auth {
proxy_pass http://localhost:8080/;
proxy_pass_request_body off;
proxy_set_header Content-Length "";
proxy_set_header X-Original-URI $request_uri;
}
}
私の場合http://localhost:8080/
、データベースに対してユーザーを認証する必要があるpythonサーバーです。ここにpythonコードがあります:
import tornado.ioloop
import tornado.web
class MainHandler(tornado.web.RequestHandler):
def post(self):
print(str(self.request))
raise tornado.web.HTTPError(403) # just test
def get(self):
print(str(self.request))
raise tornado.web.HTTPError(401) # test also
application = tornado.web.Application([
(r"/", MainHandler),
])
if __name__ == "__main__":
application.listen(8080)
tornado.ioloop.IOLoop.current().start()
今、http://localhost/private/
ブラウザでアクセスすると、次のように表示されます。
それが返す私のコードで保留中
401 Authorization Required
質問 :ユーザー名とパスワードのデータを要求/受信するには、401 例外を発生させたり、ユーザーを通過させたりすることができますか?