Hi all,

I use this code to show a recaptcha after several incorrect logins.

The essence of the work is this:
It creates the session to count the number of invalid logins and after
3 times wrong authentication emergence recaptcha. But you can simply
delete the session and thus bypass a recaptcha.
How to make display captcha could not get around?

Thanks.

Code:
html_captcha = captcha.displayhtml(settings.RECAPTCHA_PUB_KEY)
def auth(request):
    if request.method == 'POST':
        if 'captcha_on' in request.session:
            check_captcha = captcha.submit(request.POST
['recaptcha_challenge_field'],
                                           request.POST
['recaptcha_response_field'],
 
settings.RECAPTCHA_PRIVATE_KEY, request.META['REMOTE_ADDR'])
            if check_captcha.is_valid is False:
                form = AuthForm()
                return render_to_response('registration/login.html',
{'form' : form, 'error_captcha' : 1, 'html_captcha' : html_captcha})
        form = AuthForm(request.POST)
        if form.is_valid():
            username = form.cleaned_data['username']
            password = form.cleaned_data['password']
            user = authenticate(username=username, password=password)
            if user is not None:
                if user.is_active:
                    login(request, user)
                    # Redirect to a success page.
                    return HttpResponseRedirect('/')
                else:
                    # Return a 'disabled account' error message
                    return render_to_response('registration/
login.html', {'form' : form, 'html_captcha' : html_captcha,
'error_login': 1})
            else:
                # Return an 'invalid login' error message.
                if 'bad_login' in request.session:
                    count_bad_login = request.session.get('bad_login')
                    if count_bad_login == 3:
                        request.session['captcha_on'] = True
                        return render_to_response('registration/
login.html', {'form' : form, 'html_captcha' : html_captcha,
'error_login': 1})
                    request.session['bad_login'] = count_bad_login + 1
                    print count_bad_login
                    return render_to_response('registration/
login.html', {'form' : form, 'error_login': 1})
                request.session['bad_login'] = True
                return render_to_response('registration/login.html',
{'form' : form, 'error_login': 1})
        return render_to_response('registration/login.html', {'form' :
form, 'error_login': 1})
    else:
        form = AuthForm()
    return render_to_response('registration/login.html', {'form':
form})

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to