Комментарий формы Django всегда возвращает GET-запросы, POST-запрос 'Method Not Allowed'

Я пытаюсь реализовать функцию, при которой зарегистрированные пользователи могут комментировать записи в блоге, но я немного застрял с появлением комментариев на странице.

Я могу вводить комментарии и отправлять их. Однако при этом всегда возвращается GET-запрос. Я попробовал добавить method='post' к тегам формы и кнопки, но это привело к следующему:

Method Not Allowed (POST): /post/1/
Method Not Allowed: /post/1/

Я не совсем понимаю, в чем проблема. Любая помощь будет очень признательна. Фрагменты кода ниже.

post_detail.html с разделом комментариев:

   <div class="content-section">

    <legend class="border-bottom">Comments:</legend>

    {% if user.is_authenticated %}
      
      <form id="commentForm">
        {% csrf_token %}
        <fieldset class="form-group">
          <div class="row">
            <!-- <div class="col"></div> -->
            <div class="col-1 text-right">
              <img class="img-comment" src="{{ user.profile.image.url }}">
            </div>
            <div class="col-9">
              <textarea type="text" id="commentIn" name="comment" 
               placeholder="Your comment..." required></textarea> 
            </div>
            <div class="col"></div>
          </div>
          <div class="row">
            <div class="col-10 text-right">
              <button id="commentBtn" name="comment_button" 
                      class="btn btn-outline-info" type="submit">Comment</button>
            </div>
            <div class="col"></div>
          </div>
          <hr>
        </fieldset>
      </form>
    {% endif %}

    
    <div id="commentDiv">
      {% for cmnt in comments_list %}
        <img class="img-comment" 
        src="{{cmnt.commentator.profile.image.url }}">
        <a class="mr-2" >{{ cmnt.commentator }}</a>
        <p class="article-content">{{ cmnt.comment }}</p>
      <hr>
      {% endfor %}
    </div>

  </div>

urls.py в приложении blog app

urlpatterns = [
    path('post/<int:pk>/', PostDetailView.as_view(), name="post-detail"),

models.py

class Post(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField()
    date_posted = models.DateTimeField(default=timezone.now)
    author = models.ForeignKey(User, on_delete=models.CASCADE)
    likes = models.ManyToManyField(User, related_name='like')
    
    def __str__(self):
        return self.title

    def get_absolute_url(self):
        return reverse('post-detail', kwargs={'pk': self.pk})


class Comment(models.Model):
    commentator = models.ForeignKey(User, on_delete=models.CASCADE)
    blog = models.ForeignKey(Post, on_delete=models.CASCADE)
    comment = models.CharField(max_length=200)
    date_added = models.DateTimeField(default=timezone.now)

    class meta:
        verbose_name_plural = 'comments'

    def __str__(self):
        return self.comment

views.py

class PostDetailView(DetailView):
    model = Post
    form = CommentForm()

    def get_context_data(self, **kwargs):

        if self.request.method == 'GET':
            print('Render a blank form for users to fill out')
            print(self.form)

        elif self.request.method == 'POST':
            print('Get the data from the POST request')
            print(self.form)

        status = 0
        if self.request.user in self.object.likes.all():
            status = 1
        context = super().get_context_data(**kwargs)
        context['comments_list'] = Comment.objects.filter(blog=self.object)
        context['status'] = status
        return context

и, наконец, сама форма:

class CommentForm(forms.ModelForm):
    class Meta:
        model = Comment
        fields = ['comment']

Не смешивайте представление на основе класса с представлением на основе метода. Вы должны предоставить функцию, которая читает метод и ведет себя так, как должна. Для get у вас обычно есть встроенные решения, например form_class - в post() вы можете вызвать ее через form = self.get_form(). Обычно это выглядит следующим образом:

class PostDetailView(DetailView):
    model = Post
    form_class = CommentForm

    def post(self, request, *args, **kwargs):
        form = self.get_form()
        print('Get the data from the POST request')
        print(form)

    def get_context_data(self, **kwargs):
        status = 0
        if self.request.user in self.object.likes.all():
            status = 1
        context = super().get_context_data(**kwargs)
        context['comments_list'] = Comment.objects.filter(blog=self.object)
        context['status'] = status
        return context

Другие вещи, которые можно проверить, т.е. здесь: https://stackoverflow.com/a/45661979/12775662

Вернуться на верх