Vue全栈开发旅游网项目(10)-设计用户模型

1.设计用户模型

文件地址:accounts/models.py

1.1 用户详细信息

内容包括:性别 手机号 年龄 生日 真实姓名

创建常量:1-男,0-女;editable=False不许循环

class Profile(models.Model):SEX_CHOICES={(1,'男'),(0,'女')}username = models.CharField('用户名',max_length=64, unique=True,editable=False)user = models.OneToOneField(User,related_name="profile",on_delete=models.CASCADE)real_name = models.CharField('真实姓名',max_length=32)email = models.CharField('电子邮件',max_length=128,null=True,blank=True)is_email_valid = models.BooleanField('电子邮件是否已经被验证',default=False)phone_no = models.CharField('手机号码',max_length=20,null=True,blank=True)is_phone_valid = models.BooleanField('电话号码是否已经被验证', default=False)sex = models.SmallIntegerField('性别',default=1,choices=SEX_CHOICES)age = models.SmallIntegerField('年龄', default=0)source = models.CharField('登录的来源',max_length=16,null=True)version = models.CharField('登录的版本',max_length=32,null=True)created_at = models.DateTimeField('登录时间',auto_now_add=True)updated_at = models.DateTimeField('修改时间',auto_now=True)class Meta:db_table = "accounts_user_profile"

1.2  用户登录日志

class LoginRecord(models.Model):user = models.ForeignKey(User,related_name='login_records',on_delete=models.CASCADE)username = models.CharField('登录的账号',max_length=64)ip = models.CharField('IP',max_length=32)address = models.CharField('地址',max_length=32,null=True,blank=True)source = models.CharField('登录的来源',max_length=16,null=True)version = models.CharField('登录的版本', max_length=16, null=True)created_at = models.DateTimeField('登录的时间',auto_now_add=True)class Meta:db_table = "accounts_login_record"

2.数据迁移

python manage.py check

python manage.py makemigrations

python manage.py migrate 

3.准备Django模板

3.1 创建用户模板文件

3.2 用户登录

文件地址:accounts/templates/user_login.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>用户登录</title>
</head>
<body><h3>用户登录</h3><form method="post" action="."><div><!--用户名-->{{ form.username.label }}<!--用户名文字提示-->{{ form.username }}<!--用户名文本-->{{ form.username.errors.as_text }}<!--用户名错误--></div><div><!--密码-->{{ form.password.label }}<!--密码文字提示-->{{ form.password }}<!--密码文本-->{{ form.password.errors.as_text }}<!--密码错误--></div><div>{{ form.non_field_errors.as_text }} <!--验证错误提示--></div><input type="submit" value="登录"></form>
</body>
</html>

3.3 用户基本信息

文件地址:accounts/templates/user_info.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>用户的基本信息</title>
</head>
<body><p>当前登录的用户是:{{ user.username }}-{{ user.email }}</p>{% if user.is_authenticated %}<a href="/accounts/user/logout">退出登录</a>{% endif %}
</body>
</html>

3.4 配置setting

import os
MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware',# 'django.middleware.csrf.CsrfViewMiddleware',👈把它删咯'django.contrib.auth.middleware.AuthenticationMiddleware','django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
]TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [os.path.join(BASE_DIR / 'templates')],👈加上os.path.join'APP_DIRS': True,'OPTIONS': {'context_processors': ['django.template.context_processors.debug','django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},
]

4.表单验证

新建文件:accounts/forms.py

继承父类 重写子类

import re
from django import forms
from django.contrib.auth import authenticate, login
from django.utils.timezone import nowclass LoginForm(forms.Form):# 登录表单username = forms.CharField(label='用户名',max_length=100,required=False,help_text='使用帮助',initial='admin')password = forms.CharField(label='密码',max_length=200,min_length=6,widget=forms.PasswordInput)#初始化函数,将传入的数据给到父类中处理def __init__(self,*args,**kwargs):super().__init__(*args,**kwargs)self.user = None#验证用户名的钩子函数def clean_username(self):username = self.cleaned_data['username']pattern = r'^1[0-9]{10}$'if not re.search(pattern,username):raise forms.ValidationError('手机号%s输入不正确',code='invalid_phone',params=(username,))return username#用户名密码验证def clean(self):data = super().clean()if self.errors:return#获取模板中输入的用户名密码username = data.get('username',None)password = data.get('password',None)#验证用户名密码是否正确user = authenticate(username=username,password=password)if user is None:raise forms.ValidationError('用户名或密码不正确')else:if not user.is_active:raise forms.ValidationError('该用户已经被禁用')self.user = userreturn data#登陆函数def do_login(self,request):user = self.user#调用登录login(request, user)#修改登陆时间user.last_login = now()user.save()return user

5.用户登录视图函数

from django.contrib.auth import logout
from django.shortcuts import render, redirect
from accounts.forms import LoginForm
def user_login(request):#用户登录if request.method == 'POST':form = LoginForm(data=request.POST)if form.is_valid():form.do_login(request)print('表单验证通过')return redirect('/accounts/user/info/')else:print(form.errors)else:form = LoginForm()return render(request,'user_login.html',{'form':form})def user_info(request):#用户信息print(request.user)return render(request, 'user_info.html')def user_logout(request):#退出登录logout(request)return redirect('/accounts/user/info/')

6.配置路由

新建文件:accounts/urls.py

from django.urls import path
from accounts import viewsurlpatterns = [#用户登录path('user/login/',views.user_login,name='user_login'),#用户详细信息path('user/info/',views.user_info,name='user_info'),#用户退出登录path('user/logout/',views.user_logout,name='user_logout')
]

全局urls:

7.登录结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885728.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++初阶——vector

一、什么是vector vector是表示可变大小的数组的序列容器&#xff0c;就像数组一样&#xff0c;vector也采用连续空间来存储元素。也就是说它的访问和数组一样高效&#xff0c;但是它的大小是动态可变的&#xff0c;并且它的大小会被容器自动处理。 二、vector的构造 常用的构…

迁徙线,动态轨迹线

使用canvas结合贝塞尔曲线实现&#xff0c;效果如下 <template><div class"box"><div class"mapBox"><div class"map"><img src"/img/dataCockpit/map.png" alt"" /><div class"dot&…

SQLI LABS | Less-39 GET-Stacked Query Injection-Intiger Based

关注这个靶场的其它相关笔记&#xff1a;SQLI LABS —— 靶场笔记合集-CSDN博客 0x01&#xff1a;过关流程 输入下面的链接进入靶场&#xff08;如果你的地址和我不一样&#xff0c;按照你本地的环境来&#xff09;&#xff1a; http://localhost/sqli-labs/Less-39/ 本关是堆…

NVM 介绍及使用指南

在日常的开发工作中&#xff0c;我们往往会遇到需要在同一台机器上同时管理多个版本的 Node.js 的情况。为了解决这个问题&#xff0c;我一个同事推荐了NVM&#xff08;Node Version Manager&#xff09;。NVM 是一个用于管理 Node.js 版本的工具&#xff0c;可以方便地在不同的…

web——[SUCTF 2019]EasySQL1——堆叠注入

这个题主要是讲述了堆叠注入的用法&#xff0c;来复现一下 什么是堆叠注入 堆叠注入&#xff1a;将多条SQL语句放在一起&#xff0c;并用分号;隔开。 1.查看数据库的名称 查看数据库名称 1;show databases; 发现有名称为ctftraining的数据库 2.对表进行查询 1;show tabl…

【ARM】MDK-烧录配置文件无权限访问

【更多软件使用问题请点击亿道电子官方网站】 1、 问题场景 客户代码编译正常、调试出现报错<Error: Flash Download failed - "Cortex-M4"> 仿真器识别正常&#xff0c;keil-Debug内显示相关信息、设备启动正常。 记录排查步骤&#xff0c;找到配置文件位…

深度解析 ICP 备案、公安备案、等保备案编号与统一社会信用代码

1. 前言 在当今数字化时代&#xff0c;各类网站和系统如雨后春笋般涌现&#xff0c;为了确保网络安全、合法运营以及用户信息保护&#xff0c;不同类型的备案工作应运而生。其中&#xff0c;ICP 备案、公安备案和等保备案尤为重要&#xff0c;它们各自对应的备案编号不仅是一串…

11个简单易用的电商购物车设计案例

文章目录 前言正文1.扁平化设计购物车2.无表格布局购物车3.美食购物车4.响应式购物车5.jQuery购物车6.动态价格更新购物车7.标签式滑动购物车8.动态商店与购物车一体化设计9.简约清爽的购物车设计10.基于Vue.js的购物车11.域名购物车 总结 前言 现在的电子商务网站&#xff0c…

turtlesim修改窗口大小;添加自己的小乌龟;

目前手边有humble版本ROS。以此为教程。其他版本以此类推 github中搜索ros&#xff0c;然后选择ros官网&#xff08;九点方阵那个图标&#xff09;。然后 在branch中&#xff0c;选择humble&#xff0c;然后复制链接。 git clone https://github.com/ros/ros_tutorials.git -…

电阻按材料分类、不同的电阻

TOC 按电阻材料工艺进行分类 3.1.线绕电阻&#xff1a; 使用高电阻率的康铜、锰铜或镍铬合金丝缠绕在陶瓷骨架&#xff08;一般采用陶瓷、塑料、涂覆绝缘层的金属骨架&#xff09;上制作而成的。玻璃釉绕线电阻表面被覆一层玻璃釉&#xff1b;涂漆线绕电阻表面被覆一层保护有…

spark的学习-06

SparkSQL读写数据的方式 1&#xff09;输入Source 方式一&#xff1a;给定读取数据源的类型和地址 spark.read.format("json").load(path) spark.read.format("csv").load(path) spark.read.format("parquet").load(path) 方式二&#xff1a…

react-markdown内容宽度溢出和换行不生效问题

情景复现&#xff1a; 解决办法&#xff0c;添加样式进行限制 /* index.css */ .markdown-container {word-break: break-word; /* 强制长单词断行 */white-space: pre-wrap; /* 保留空白符序列&#xff0c;但是正常地进行换行 */overflow-wrap: break-word; /* 在长单词或…

java双向链表解析实现双向链表的创建含代码

双向链表 一.双向链表二.创建MyListCode类实现双向链表创建一.AddFirst创建&#xff08;头插法&#xff09;二.AddLast创建&#xff08;尾叉法&#xff09;三.size四.remove(指定任意节点的首位删除)五.removeAll(包含任意属性值的所有删除)六.AddIndex(给任意位置添加一个节点…

VMWare虚拟机NAT模式下与外部主机(非宿主机)通信

VMWare虚拟机NAT模式下与外部主机(非宿主机)通信 1. VMWare虚拟机网络 VMWare的三种网络工作模式&#xff1a; Bridged&#xff1a;桥接模式NAT&#xff1a;网络地址转换模式Host-Only &#xff1a;仅主机模式 VMWare 网络连接配置界面如下&#xff1a; 在本次测试环境中&a…

Mac保护电池健康,延长电池使用寿命的好方法

使用Mac的过程中&#xff0c;如何延长电池的使用寿命是大家非常关心的问题&#xff0c;而养成一个良好的充电习惯能够有效的延长电池的使用寿命 避免过度充电和过度放电能够有效的保护电池&#xff0c;因此长时间的充电与长时间放点都不可取&#xff0c;但是在日常的使用过程中…

显示器接口种类 | 附图片

显示器接口类型主要包括VGA、DVI、HDMI、DP和USB Type-C等。 VGA、DVI、HDMI、DP和USB Type-C 1. 观察 VGA接口:15针 DP接口&#xff1a;在DP接口旁&#xff0c;都有一个“D”型的标志。 电脑主机&#xff1a;DP(D) 显示器&#xff1a;VGA(15针) Ref https://cloud.tenc…

qt QUndoCommand 与 QUndoStack详解

1、概述 QUndoCommand 和 QUndoStack 是 Qt 框架中用于实现撤销/重做&#xff08;undo/redo&#xff09;功能的两个核心类。QUndoCommand 是表示单个可撤销操作的基类&#xff0c;而 QUndoStack 则负责管理这些命令的堆栈&#xff0c;提供撤销和重做操作的接口。 QUndoCommand…

双指针(二)双指针到底是怎么个事

一.有效的三角形个数 有效的三角形个数 class Solution {public int triangleNumber(int[] nums) {Arrays.sort(nums);int i0,end nums.length-1;int count 0;for( i end;i>2;i--){int left 0;int right i-1;while(left<right){if(nums[left]nums[right]>nums…

springboot的增删改查商城小实践(b to c)

首先准备一张表&#xff0c;根据业务去设计表 订单编号是参与业务的&#xff0c;他那订单编号里面是有特殊意义的&#xff0c;比如说像什么一些年月日什么的&#xff0c;一些用户的ID都在那编号里面呢&#xff1f;不能拿这种东西当主件啊 根据数据量去决定数据类型 价格需要注意…

动态规划-背包问题——416.分割等和子集

1.题目解析 题目来源 416.分割等和子集——力扣 测试用例 2.算法原理 1.状态表示 这里背包问题基本上和母题的思路大相径庭&#xff0c;母题请见 [模板]01.背包 &#xff0c;这里的状态表示与装满背包的情况类似&#xff0c;第二个下标就是当选择的物品体积直接等于j时是否可…