Django перестает обновлять данные в mysql после обновления страницы

Я довольно новичок в использовании фреймворка django и недавно я сделал систему с ним, где он отправляет данные в mysql db через html форму. В конце концов, я заставил ее работать, и все выглядело вполне нормально, однако я заметил ошибку, когда при обновлении страницы django перестает отправлять данные в mysql, случалось ли такое с кем-нибудь?

Материалы для справки:

views.py

from django.shortcuts import render
from websiteDB.models import dbInsert
from django.contrib import messages

def insertToDB(request):
    if request.method == "POST":

        if request.POST.get('uname') and request.POST.get('email') and request.POST.get('message'):
            post = dbInsert()
            post.uname = request.POST.get('uname')
            post.email = request.POST.get('email')
            post.message = request.POST.get('message')
            post.save()
            messages.success(request, "Message sent successfully.")
        return render(request, "contact.html")

    else:
        return render(request, "contact.html")

models.py

from django.db import models

class dbInsert(models.Model):
    uname = models.CharField(max_length=100)
    email = models.EmailField()
    message = models.TextField()
    class Meta:
        db_table = "contactrequest"

urls.py

"""
websiteDB URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:
    https://docs.djangoproject.com/en/4.0/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
from django.views.generic import TemplateView
from . import views
from . import index

urlpatterns = [
   #path('admin/', admin.site.urls),

   path('homepage', index.page_home, name= 'hpage'),
   path('', views.insertToDB),
   path('contactpage', index.contact_page, name= 'cpage')
]

contact.html

{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Outfit:wght@200&display=swap" rel="stylesheet">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="{% static 'css/css/styles.css' %}">
    <title>Document</title>
</head>
<body style="background-color: rgb(74, 36, 110);">

    <script src="{% static 'js/main.js' %}"></script>

    <div class="top-nav">
        <a href="{% url 'hpage' %}">HOME</a>
        <a href="products.html">PRODUCTS</a>
        <a href="contact.html">CONTACT</a>
        <a href="about.html">ABOUT</a>
        <a href="community.html">COMMUNITY</a>
        </div>

        <div class="div-align">

            <h2>Contact</h2>
            <p>Reach us for questions/concerns through the form below.</p>
        </div>  
    <form class="fontmaker" method="post">
        {% csrf_token %}
        <label for="Username">Username:</label><br>
        <input type="text" id="Username" name="uname" required><br>
        <label for="E-mail">E-mail:</label><br>
        <input type="text" id="Email" name="email" required>
        <label for="Reason" class="margin">Message:</label>
        <textarea id="Reason" name="message" rows="10" cols="60" required>Type your reason of contact here.</textarea>
        <input type="submit" value="Submit" class="rounded-corners" id="submitBtn">

        {% if messages %}
        {% for message in messages %}
            {{message}}
        {% endfor %}
        {% endif %}
        
    </form>
    
</body>
</html>

В терминале нет ошибок, и нажатие кнопки также правильно отправляет POST-запрос: Вывод терминала

Я также новичок в размещении информации на stackoverflow, скажите мне, есть ли что-то еще, что можно улучшить в будущем при размещении информации.

Заранее спасибо.

Если вы отображаете URL contactpage/, то при отправке формы вы отправляете ее в представление contact, но это представление не обрабатывает данные и не создает никаких записей. Вы должны убедиться, что вы отправляете форму в представление insertToDB. Вы можете сделать это, дав представлению имя:

urlpatterns = [
    # …,
    path('', views.insertToDB, name='insertToDB'),
    # …
]

и затем укажите конечную точку в форме:

<form class="fontmaker" method="post" action="{% insertToDB %}">
    <!-- … -->
</form>

В случае успешного POST запроса, вы также должны перенаправить, например, с:

from django.shortcuts import redirect

def insertToDB(request):
    if request.method == 'POST':
        if request.POST.get('uname') and request.POST.get('email') and request.POST.get('message'):
            post = dbInsert.objects.create(
                uname = request.POST['uname'],
                email = request.POST['email'],
                message = request.POST['message']
            )
            messages.success(request, 'Message sent successfully.')
            return redirect('cpage')
        return render(request, 'contact.html')

    else:
        return render(request, 'contact.html')

Я бы посоветовал поработать с Django forms [Django-doc], например modelform [Django-doc] для валидации и очистки ввода формы и удаления большого количества кодового кода.

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