Pour préparer l'autorisation avec captcha, nous avons besoin de
nginx lui-même et de ses plugins
crypted-session ,
form-input ,
ctpp2 ,
echo ,
ldap ,
headers-more ,
auth_request ,
set-misc . (J'ai donné des liens vers mes fourches, car j'ai apporté des modifications qui n'ont pas encore été entassées dans les référentiels d'origine. Vous pouvez également utiliser l'
image prête à l'
emploi .)
Pour commencer, réglons
encrypted_session_key "abcdefghijklmnopqrstuvwxyz123456";
Ensuite, juste au cas où, désactivez l'en-tête d'autorisation
more_clear_input_headers Authorization;
Maintenant, nous protégeons tout avec autorisation
auth_request /auth; location =/auth { internal; subrequest_access_phase on;
Pour les utilisateurs autorisés, nous affichons le contenu de leur dossier
location / { alias html/$remote_user/; }
Et en l'absence d'autorisation, nous montrons le formulaire d'autorisation avec captcha
error_page 401 = @error401; location @error401 { set_escape_uri $request_uri_escape $request_uri;
login.html
<html> <body> <form method="post"> <input type="hidden" name="csrf" value="<TMPL_var csrf>" /> username: <input type="text" name="username" placeholder="Enter User Name..." /><br /> password: <input type="password" name="password" /><br /> captcha: <img src="/captcha?csrf=<TMPL_var csrf>"/><input type="text" name="captcha" autocomplete="off" /><br /> <input type="submit" name="submit" value="submit" /> </form> </body> </html>