【发布时间】:2016-01-02 09:49:00
【问题描述】:
我有一个简单的 Like 按钮,与 @csrf_exempt 一起使用时效果很好:
模板
<p id="like_count"> {{ topic.likes }}</p>
<span data-type="topic" title="Like"> {% csrf_token %}
<i class="fa fa-thumbs-up" id="liket" name="{{topic.id}}">
阿贾克斯
$(function(){
$('#liket').click(function(){
$.ajax({
type: "POST",
url: "/like/",
data: {
'topic_id': $(this).attr('name'),
'csrfmiddlewaretoken': '{{csrf_token}}'
},
success: tlikeSuccess,
dataType: 'html'
});
});
});
function tlikeSuccess(data, textStatus, jqXHR)
{
$('#like_count').html(data);
}
和观点:
#@csrf_exempt
def topic_like(request):
args = {}
if request.method == 'POST':
user = request.POST.get('user')
lu= request.user #User.objects.get(username= user)
topic_id = int(request.POST.get('topic_id'))
try:
liked_topic = Topic.objects.get(id = topic_id)
except:
liked_topic = None
if TopicLike.objects.filter(liker=request.user.id, topic=topic_id).exists():
liked_topic.likes -=1
liked_topic.save()
TopicLike.objects.filter(topic=topic_id, liker=request.user.id).delete()
else:
liked_topic.likes +=1
liked_topic.save()
newliker = TopicLike(topic=topic_id, liker=request.user.id)
newliker.save()
#args.update(csrf(request))
args['likes'] = str(liked_topic.likes)
return render(request, 'ajax_like.html', args)
但是我不喜欢这种忽略 CSRF 的解决方法,因为它可能容易受到攻击。 另一方面,我无法将新的 CSRF 令牌返回到模板,因此我感谢您将 CSRF 集成到此按钮中的提示。
【问题讨论】:
-
Django docs 建议在标题中而不是在帖子数据中提供 csrf 令牌。
-
@Alasdair 请给我一个完整的答案。我不知道如何应用文档的建议。
-
我认为文档很清楚。你尝试了什么?你认为缺少什么?你不明白哪一部分?
标签: ajax django django-templates django-csrf