首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >django使用链接或表单注销,以防止csrf漏洞利用

django使用链接或表单注销,以防止csrf漏洞利用
EN

Stack Overflow用户
提问于 2012-03-30 01:05:37
回答 1查看 1.2K关注 0票数 2

在阅读djangobook chapter的时候,我偶然看到一段提到csrf漏洞的文章,其中一个注销链接被放在一个隐藏的恶意网站中。

在我使用django创建的web应用程序中,我使用了类似的注销链接

base.html:

代码语言:javascript
复制
<a  href="{% url my_logout %}" > Logout </a>

my_logout url指向django.contrib.auth.views.logout_then_login的位置

代码语言:javascript
复制
urlpatterns=patterns('django.contrib.auth.views',
url(r'^logout/$', 'logout_then_login', {}, name = 'my_logout'),
)

现在,在阅读了csrf攻击后,我担心恶意网站会给我带来麻烦too.So,我想使用一个表单来做注销。

我想我可以这样做

base.html:

代码语言:javascript
复制
    ...

    <form method="post" action=".">{% csrf_token %}
        <input type="hidden" name="next" value="{{next}}" />
        <input type="hidden" name="confirm" value="true" />
        <input type="submit" value="Logout" />
    </form>
...

现在,我应该如何编写处理这个表单的视图呢?如果我要处理隐藏的变量(使用confirm检查是否应该注销,使用next则转到上一个视图),我是否仍然可以使用django.contrib.auth.views.logout_then_login方法?

有没有人能告诉我,我这样做是不是正确?

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-03-30 01:31:58

你可以把它包装成这样

代码语言:javascript
复制
from django.views.decorators.cache import never_cache
from django.views.decorators.csrf import csrf_protect
from django.views.decorators.http import require_POST

@csrf_protect
@require_POST
@never_cache
def safer_logout(request):
    # 'confirm' is useless here, POST implies 'do it'
    return logout_then_login(request, request.POST.get('next'))

另外,考虑使用SESSION_COOKIE_HTTPONLY

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9930068

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档