django-recaptcha не проверяет ввод

Я пытаюсь интегрировать django-recaptcha с django-регистрацией. Я уже убедился, что django-регистрация работает. Затем я устанавливаю и настраиваю django-recaptcha в соответствии с его документом ( django-recaptcha 0.0.6).

Я добавляю captcha = ReCaptchaField() в RegistrationForm класс в registration/forms.py следующим образом:

from captcha.fields import ReCaptchaField

class RegistrationForm(forms.Form):
    required_css_class = 'required'
    username = forms.RegexField(regex=r'^[\w.@+-]+$', max_length=30, label=_("Username"), error_messages={'invalid': _("This value may contain only letters, numbers and @/./+/-/_ characters.")})
    email = forms.EmailField(label=_("E-mail"))
    password1 = forms.CharField(widget=forms.PasswordInput, label=_("Password"))
    password2 = forms.CharField(widget=forms.PasswordInput, label=_("Password (again)"))

    captcha = ReCaptchaField()

    ...

Появляется капча, но независимо от того, что я набрал в тексте chptcha (ничего не введите, правильно или неправильно), после нажатия "Bottom" всегда отображается "Это поле обязательно для заполнения". (конечно, я ввел два поля пароля).

ошибка с проверкой

Это не должно быть проблемой с закрытым / открытым ключом, так как при неправильной настройке капча не будет отображаться, но появится текст ошибки. Любая идея?

Кстати, я использую Python 2.7 с Django 1.4.3. И я протестировал два браузера: Chrome и IE9.

[ОБНОВЛЕНО]

Я обнаружил, что основной причиной этой проблемы является то, что набранный мной текст не передается в запрос POST, как показано ниже:

POST:<QueryDict: {u'username': [u'test123'], u'password1': [u'123'], u'csrfmiddlewaretoken': [u'BUvEURhlUMYDx1DjztgdRuK1CrI7WanY'], u'email': [u'test@gmail.com'], u'password2': [u'123']}>,

Исходный код HTML, отображаемый в браузере клиента, отображается следующим образом. Обычно он должен иметь " recaptcha_challenge_field " в запросе POST, но я не уверен, почему браузер клиента не отправляет эту переменную в запросе POST. Я совершенно новичок в сценарии Java. Любая идея?

<!doctype html>
<html>
    <head>
        <title>Register for an account</title>
    </head>
    <body>

<table>
    <form method='post' action=''><div style='display:none'><input type='hidden' name='csrfmiddlewaretoken' value='BUvEURhlUMYDx1DjztgdRuK1CrI7WanY' /></div>
        <tr class="required"><th><label for="id_username">Username:</label></th><td><input id="id_username" type="text" name="username" maxlength="30" /></td></tr>
<tr class="required"><th><label for="id_email">E-mail:</label></th><td><input type="text" name="email" id="id_email" /></td></tr>
<tr class="required"><th><label for="id_password1">Password:</label></th><td><input type="password" name="password1" id="id_password1" /></td></tr>
<tr class="required"><th><label for="id_password2">Password (again):</label></th><td><input type="password" name="password2" id="id_password2" /></td></tr>
<tr class="required"><th><label for="id_captcha">Captcha:</label></th><td><script type="text/javascript">
    var DjangoRecaptchaOptions = {
  "lang": "en"
};
    if (typeof RecaptchaOptions !== 'object') {
        RecaptchaOptions = DjangoRecaptchaOptions;
    } else {
        for (key in DjangoRecaptchaOptions) {
            RecaptchaOptions[key] = DjangoRecaptchaOptions[key];
        }
    }
</script>
<script type="text/javascript" src="https://www.google.com/recaptcha/api/challenge?k=6LeuNO4SAAAAAAdkaCUi6ybtISPI-YhIlOadgFNF&hl=en"></script>
<noscript>
  <iframe src="https://www.google.com/recaptcha/api/noscript?k=6LeuNO4SAAAAAAdkaCUi6ybtISPI-YhIlOadgFNF&hl=en" height="300" width="500" frameborder="0"></iframe><br />
  <textarea name="recaptcha_challenge_field" rows="3" cols="40"></textarea>
  <input type='hidden' name='recaptcha_response_field' value='manual_challenge' />
</noscript>
</td></tr>
        <tr><td></td><td><input type="submit" value="Send activation email" /></td>
    </form>
</table>

    </body>
</html>

1 ответ

Решение

Я нашел ответ! Это из-за <table> тег в registration_form.html, предоставленный пакетом django-registration. Содержание:

{% extends "registration/registration_base.html" %}
{% load i18n %}
{% block title %}{% trans "Register for an account" %}{% endblock %}
{% block content %}
<table>
    <form method='post' action=''>{% csrf_token %}
        {{ form }}
        <tr><td></td><td><input type="submit" value="{% trans "Send activation email" %}" /></td>
    </form>
</table>
{% endblock %}

К сожалению, в recaptcha есть еще <table> тег встроен в его Java-сценарий, что означает, что там будет иметь recaptcha <table> тег внутри регистрации <table> тег. Хотя браузер может правильно отображать страницу, он не может правильно получить поля, такие как "recaptcha_challenge_field" и "recaptcha_response_field" во встроенном <table>

Решение состоит в том, чтобы удалить <table> связанный тег из registration_form.html.

Другие вопросы по тегам