首页 > 解决方案 > 我正在学习django,当我使用Pinax Likes时,出现405错误

问题描述

Django 2.2.1

当我使用 Pinax Likes(https://github.com/pinax/pinax-likes)时,出现 405 错误。

步骤如下:

PINAX_LIKES_LIKABLE_MODELS = {
    "app.Post": {}
}
re_path(r'^likes/', include(('pinax.likes.urls', 'pinax_likes'), namespace='pinax_likes')),

到项目的 urls.py 文件,

将这些html文件放入 /home/www/venv/templates/pinax/likes/

{% load pinax_likes_tags %}
{% likes_widget request.user post %}

到 post.html 文件,

控制台显示以下信息:

不允许的方法 (GET):/likes/like/14:13/ 不允许的方法:/likes/like/14:13/ [29/May/2019 10:00:00] "GET /likes/like/14: 13/HTTP/1.1" 405 0

点击图标后,控制台显示如下信息:

禁止(CSRF 令牌丢失或不正确。):/likes/like/14:13/ [29/May/2019 10:01:31] "POST /likes/like/14:13/ HTTP/1.1" 403 2513

哪些步骤有误?谢谢!

标签: pythondjangopinax

解决方案


我看不到 pinax-likes 小部件实际上如何与当前代码一起工作。它坏了。我看到你打开了一个问题,如果有人仍在积极维护它,他们可能会修复它。或者您可以修复它并提出拉取请求。

有两个问题{% likes_widget %}

  1. 如果没有 ajax,它就无法工作,因为它只是一个链接,即它会向您的视图发送一个 GET 请求。但是视图需要一个 POST 请求,这是合乎逻辑的,因为喜欢会更改数据库,所以它应该是一个 POST。因此,如果没有 ajax,视图会抛出 405 错误。

  2. 它使用 eldarion-ajax 发出 ajax POST 请求,但由于这只是一个a.click事件,它不会发布任何数据,即它不会发布 CSRF 令牌。该视图不允许丢失令牌(它没有 @csrf_exempt 装饰器),因此会引发 403 错误。

现在我看到的唯一方法是编写自己的 HTML 和/或 ajax,而不是使用 likes_widget。

  1. 您可以将like 按钮包装在表单中,并将like 按钮替换为<button>提交表单的a(而不是<a>标签)。这样,您可以{% csrf_token %}在表单中包含标签,并且帖子将起作用。这将刷新页面。

  2. 您可以编写自己的 ajax 调用来处理对赞按钮的点击并发布到同一视图,并将 csrftoken 包含在发布的数据中。

这实现起来相当简单,您可以使用现有的 pinax 样视图,因此只需更改您的 HTML 模板。


推荐阅读