django_连接数据库建立账号注册登陆界面

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: django_连接数据库建立账号注册登陆界面

Django连接数据库

坏境的需要:python、pip、django、mysql和其他的一些必要类库
windows系统下载mysql官网链接:https://dev.mysql.com/downloads/installer/
下载安装好配置用户名和密码
image.png

然后再django工程的setting.py设置database
我创建的是Admin应用
下面是的配置对应mysql的账号密码和端口号(我把django默认的sqlite注释,用mysql)

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        'NAME':'video_demo',//对应mysql
        'USER':'root',
        'PASSWORD':'MaMYONG198',
        'HOST':'127.0.0.1',
        'PORT':'3306',
    }
}

image.png

init.py添加(提前下载django的pymysql类库)

import pymysql
pymysql.install_as_MySQLdb()

运行工程就可以可连接数据库了
设置model

from django.db import models
class user(models.Model):
    u_name = models.CharField(max_length=10)  # 保存用户名
    u_password = models.CharField(max_length=255)  # 保存密码
    class Meta:
        db_table = 'users'

views

from django.shortcuts import render, render_to_response
from django import forms
from django.http import HttpResponseRedirect, HttpResponse
from .models import user
from django.contrib.auth.hashers import make_password, check_password

from django.views.decorators.csrf import csrf_exempt

class UserForm(forms.Form):
    username = forms.CharField(label='用户', max_length=10)
    password = forms.CharField(label='密码', widget=forms.PasswordInput())

# 处理登录的方法

@csrf_exempt
def login01(request):
    if request.method == 'GET':
        return render(request, 'registration/login.html')
    if request.method == 'POST':
        data = UserForm(request.POST)
        if data.is_valid():
            # 获取到表单提交的值
            username = data.cleaned_data['username']
            password = data.cleaned_data['password']
            # 把表单中取到的值和数据库里做对比
            try:
                use = user.objects.get(u_name=username)
                if password == use.u_password:
                    return HttpResponseRedirect('/login/index01/')
                else:
                    return HttpResponse("密码错误")
            except:
                return HttpResponse("密码错误")
        else:
            return HttpResponse("用户不存在")
def logout01(request):  # 退出登录的方法
    if request.method == 'GET':
        response = HttpResponseRedirect('/login/login01/')
        return response
def index01(request):
    if request.method == 'GET':
        return render(request, 'registration/firstpage.html')
def loginpage(request):
    return render(request,'registration/firstpage.html')

urls
我的这个有点乱,主要理解函数

from django.urls import path
from Admin import views
from django.contrib import admin
app_name='polls'
urlpatterns=[
    path('' ,views.index01, name='index'),
    path('login/', views.login01, name='login'),
    path('page/',views.loginpage,name='loginpage'),
    path('login01/',views.login01,name='login01'),
    path('index01/',views.index01,name='index01'),
    path('logout01/',views.logout01,name='logout01'),
]

index01.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<p>测试</p>
 <a href="/login/logout01/"><span>退出</span></a>
</body>
</html>

login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
 <div style="margin: 15% 40%;">
        <h1>欢迎登录!</h1>
       <form action="/login/login01/" method="post">{% csrf_token %}
            <p>
                <label for="id_username">用户:</label>
                <input type="text" id="id_username" name="username" placeholder="用户名" autofocus required />
            </p>

            <p>
                <label for="id_password">密码:</label>
                <input type="password" id="id_password" placeholder="密码" name="password" required >
            </p>
            <input type="submit" value="确定">
        </form>
    </div>

</body>
</html>

firstpage.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>首页</title>
</head>
<body>
{% load static %}
<body background="{% static 'images/bg.png' %}"></body>
<center><p>登陆成功</p>
    <form action="/login/" method="post">{% csrf_token %}
         <input type="submit" value="退出">
        </form>
</center>
</body>
</html>

设置数据库users表的用户

image.png

运行登陆账号
image.png

输入账号登陆成功
image.png

有问题欢迎留言!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
1月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
75 13
|
1月前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
506 11
|
3月前
|
SQL XML Java
配置Spring框架以连接SQL Server数据库
最后,需要集成Spring配置到应用中,这通常在 `main`方法或者Spring Boot的应用配置类中通过加载XML配置或使用注解来实现。
299 0
|
6月前
|
Oracle 安全 关系型数据库
【Oracle】使用Navicat Premium连接Oracle数据库两种方法
以上就是两种使用Navicat Premium连接Oracle数据库的方法介绍,希望对你有所帮助!
1233 28
|
6月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
329 14
|
4月前
|
Linux 数据库 数据安全/隐私保护
Python web Django快速入门手册全栈版,共2590字,短小精悍
本教程涵盖Django从安装到数据库模型创建的全流程。第一章介绍Windows、Linux及macOS下虚拟环境搭建与Django安装验证;第二章讲解项目创建、迁移与运行;第三章演示应用APP创建及项目汉化;第四章说明超级用户创建与后台登录;第五章深入数据库模型设计,包括类与表的对应关系及模型创建步骤。内容精炼实用,适合快速入门Django全栈开发。
126 1
|
11月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
619 45
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
417 22
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面

热门文章

最新文章