1

我在这个 SO 问题中接受了建议:OpenID with Django 的最佳解决方案是什么?django-openid-auth为我的应用程序安装。

但我就是无法让它工作,CSRF verification failed. Request aborted.当我尝试登录时我总是会得到。

django csrf

我已经检查了一切:

1.

{% csrf_token %}存在于模板中:

<form name="fopenid" action="{{ action }}" method="post">
    {% csrf_token %}
    <fieldset>
        <legend>Sign In Using Your OpenID</legend>
        <div class="form-row">
            <label for="id_openid_identifier">OpenID:</label><br />
            {{ form.openid_identifier }}
        </div>
        <div class="submit-row ">
            <input name="bsignin" type="submit" value="Log in">
        </div>
 {% if next %}
        <input type="hidden" name="next" value="{{ next }}" />
 {% endif %}
    </fieldset>
</form>

2.

django_openid_auth我发现的views.py里面,他们使用RequestContext

return render_to_response(template_name, {
                    'form': login_form,
                    redirect_field_name: redirect_to
                    }, context_instance=RequestContext(request))

3.

我的MIDDLEWARE_CLASSES确实包含CsrfViewMiddleware

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
)

我只是不明白还有什么问题?你有什么想法?

我正在使用 Django 1.3 测试版。

更新

这似乎是我的全球性问题。我创建了一个简单的表单并得到了相同的结果:

def index(request):
    return render_to_response('index.html',
                              locals(),
                              context_instance=RequestContext(request))

索引.html:

<form action="/" method="post">
    {% csrf_token %}
    <input type="text" name="test">
    <input type="submit">
</form>

呈现的 HTML:

<form action="/" method="post">
    <div style="display:none"><input type="hidden" name="csrfmiddlewaretoken" value="1fbd5345560d325bf05809260f7d43c3"></div>
    <input type="text" name="test">
    <input type="submit">
</form>

怎么了!?

4

2 回答 2

1

我尝试了“manage.py runserver localhost:8000”而不是“manage.py runserver”,我猜它有一些cookie问题,因为主机名中的ip顺便说一句。我在 django 1.3 的新副本中遇到了这个错误

于 2011-06-17T15:33:19.487 回答
0

实际上,我认为这是我在 Django 中遇到的第一个错误。我已经将我的副本更新为 1.3 的新版本,一切都开始工作了。干得好,Django 开发人员!

于 2011-03-25T10:28:13.823 回答