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] для валидации и очистки ввода формы и удаления большого количества кодового кода.