目录
  • 1. 总体设计思路
  • 2. 搭建简易用户系统
    • 2.1 配置模型Model
    • 2. 2 写入数据库:
    • 2.3 数据库验证表:
    • 2.4 路由URL配置:
    • 2.5 用户增加
      • 后台执行脚本配置:
      • 视图模板配置:
      • 前端展示效果如下:
      • 用户提交,后台数据库验证:
    • 2.6 用户查询
      • 后台执行脚本配置:
      • 视图模板配置:
      • 前端展示效果如下:
      • 查询用户 ,展示如下:
    • 2.7 用户修改
      • 后台执行脚本配置:
      • 视图模板配置
      • 前端展示效果如下:
      • 修改用户,展示如下:
    • 2.8 用户删除
      • 后台执行脚本配置
      • 视图模板配置
      • 删除用户,展示如下:
    • 如果觉得这篇文章不错 ,请点赞或分享到朋友圈吧!

1. 总体设计思路

一套简单的用户管理系统,包含但不限如下功能:

  • 用户增加:用于新建用户;
  • 用户查询:用于查询用户信息;
  • 用户修改:用于修改用户信息;
  • 用户删除:用于删除用户信息;

最基本的功能就包括增、删 、改、查了 。

想要搭建好一套系统,前期肯定是要设计一套思路 ,大家按照上图对号入座即可。

下面,咋就开始实战了...

划重点了,一定要动手、一定要动手 、一定要动手 ...

2. 搭建简易用户系统

如果哪位同学还没学习过上两篇文章的 ,请速速去研究下 ,再来看这篇文章。

2.1 配置模型Model

hello\models.py

创建一个类(class)对象,这就相当于数据中的一张表(table) 。

# 创建数据库User表 class User(models.Model): # 性别, 元组用于下拉框 sex = ((0, '男'), (1, '女')) # 用户名 username = models.CharField(max_length=20, help_text='用户名') # 用户密码 password = models.CharField(max_length=16, help_text='用户密码') # sex中的0,1是存放在数据库,中文男和女是在web前端展示 sex = models.IntegerField(choices=sex, null=True, blank=True) # 手机号码 phone = models.CharField(max_length=11, help_text='手机号码') # 对象获取返回值为用户名 def __str__(self): return self.username

2. 2 写入数据库:

后台会转换成sql语句写入数据库 ,看起来是不是很方便,也不用太懂sql了,这也是ORM 的强大之处。

(py369) [root@localhost devops]# python manage.py makemigrations hello Migrations for 'hello': hello/migrations/0005_auto_20201105_2336.py - Create model User - Alter field id on devices (py369) [root@localhost devops]# python manage.py migrate Operations to perform: Apply all migrations: admin, auth, contenttypes, hello, sessions Running migrations: Applying hello.0005_auto_20201105_2336... OK

2.3 数据库验证表:

我是通过Navicat Premium工具连接数据库 ,进行可视化查看,你用哪个工具都可以。

2.4 路由URL配置:

hello\urls.py

name='xxxx',这是命名空间的用法 ,常在模板使用此方式:hello:adduser,等同于hello/adduser.html, 好处就是不用担心你的path随意改变 。

from django.urls import path from django.urls import re_path from hello import view app_name = 'hello' urlpatterns = [ # FBV,通过函数方式,实现增删改查 # 增加 path('adduser/', view.adduser, name="adduser"), # 查询 path('showuser/', view.showuser, name="showuser"), # 修改 re_path('edituser/(?P[0-9]+)?/', view.edituser, name="edituser"), # 删除 re_path('deluser/(?P[0-9]+)?/', view.deluser, name="deluser"), ]

2.5 用户增加

后台执行脚本配置:

hello\view.py

from django.shortcuts import render from django.http import HttpResponse, QueryDict from django.shortcuts import get_object_or_404 from django.http import Http404 from hello.models import User import traceback # 用户增加函数 def adduser(request): msg = {} if request.method == 'POST': try: print(request.POST) # 将数据转为字典格式 data = request.POST.dict() # 将数据一次性写入数据库 User.objects.create(**data) msg = {'code':0, 'result':'已成功添加用户.'} except: msg = {'code':1, 'result':'添加用户失败:'.format(traceback.format_exc())} return render(request, "hello/adduser.html", {'msg':msg})

视图模板配置:

templates\hello\adduser.html

{% extends "base.html" %} {% block title %} 用户添加 {% endblock %} {% block body %} {% if msg.code == 0 %}

{{ msg.result }}

{% else %}

{{ msg.result }}

{% endif%}

添加用户信息


用户:

密码:

手机号:

性别:

{% endblock%}

前端展示效果如下:

打开浏览器 ,输入如下链接格式:http://ip/hello/adduser

用户提交,后台数据库验证:

认真填写好信息后,点击提交 ,成功的话就会显示已成功添加用户 ,另外可以到后台DB去验证下。

我一口气创建了6个用户,我任性。

备注:各位先忽略数据库表中密码是明文,后续实战中会是密文的 ,不用担心密码泄漏 。

2.6 用户查询

后台执行脚本配置:

hello\view.py

# 新增代码块 # 用户查看函数 def showuser(request): # http://192.168.8.130:8888/hello/showuser/?keyword=test001 # 获取关键位置参数,get获取唯一值,''表示缺省参数 ,防止报错 keyword = request.GET.get('keyword', '') # 获取所有数据 users = User.objects.all() # 如果关键位置参数不为空 if keyword: # 用户名不区分大小写过滤 users = users.filter(username__icontains=keyword) # return 返回两个参数'users'和'keyword'传到前端 return render(request, 'hello/showuser.html', {'users':users, 'keyword':keyword})

视图模板配置:

templates\hello\showuser.html

{% extends "base.html" %} {% block title %} 用户查询 {% endblock %} {% block body %}

查询用户信息



{% for user in users %} {% endfor %}
ID 用户名 密码 手机号码 性别 操作
{{ user.id }} {{ user.username }} {{ user.password }} {{ user.phone }} {% if user.sex == 0 %}男 {% elif user.sex == 1 %}女 {% else %}none {% endif %} 更新 删除
{% endblock%}

前端展示效果如下:

查询用户,展示如下:

此时后台是通过username来过滤 ,后期我们会通过Q方法来过滤多个字段 。

2.7 用户修改

后台执行脚本配置:

hello/view.py

重点说明: 不管是用户查询还是删除,重点以ID (数据库中的主键)进行操作,不要使用其他字段。

# 新增代码 ,用户修改函数 def edituser(request, **kwargs): msg = {} pk = kwargs.get('pk', '') # 先检查pk是否存在,不存在则报404错误 user = get_object_or_404(User, pk=pk) if request.method == 'POST': try: data = request.POST.dict() User.objects.filter(pk=pk).update(**data) msg = {'code':0, 'result':'已成功更新用户'} except: msg = {'code':1, 'result':'用户更新失败: '.format(traceback.format_exc())} return render(request, 'hello/edituser.html', {'user':user, 'msg':msg})

视图模板配置

templates\hello\edituser.html

{% extends "base.html" %} {% block title %} 更新用户 {% endblock %} {% block body %} {% if msg.code == 0 %}

{{ msg.result }}

{% else %}

{{ msg.result }}

{% endif %}

更新用户信息


用户名:

密码:

手机号码:

性别: {% if user.sex == 0 %} 女 {% else %} 女 {% endif %}

{% endblock%}

前端展示效果如下:

在用户列表的操作项,点击更新 ,跳转该页面:

修改用户 ,展示如下:

将用户名test006的性别修改为,结果如下:

pk不存在的时候,测试效果如下:

后台数据库查表验证下:

2.8 用户删除

后台执行脚本配置

hello\view.py

# 新增代码, 用户删除函数 def deluser(request, **kwargs): msg = {} pk = kwargs.get('pk', '') try: # 获取单个用户信息 user = User.objects.get(pk=pk) except User.DoesNotExist: # 如果用户不存在 ,则返回404错误 raise Http404 if request.method == 'POST': try: User.objects.get(pk=pk).delete() msg = {'code':0, 'result':'已成功删除用户'} except: msg = {'code': 1, 'result': '用户删除失败: '.format(traceback.format_exc())} return render(request, 'hello/deluser.html', {'user':user, 'msg':msg})

视图模板配置

templates\hello\deluser.html

{% extends "base.html" %} {% block title %} 删除用户信息 {% endblock %} {% block body %} {% if msg.code == 0 %}

{{ msg.result }} {{ user.username }}

{% else %}

{{ msg.result }}

{% endif %}

删除用户信息

Are you sure to delete {{ user.username }}?

{% endblock%}

删除用户,展示如下:

在用户列表的操作项,点击删除 ,点击确定,已成功返回`:

删除失败效果如下:

至此,一套简易的用户系统已经完成啦 ,看起来是不是很简单,大家跟着练习一把,有问题 ,请随时讨论,谢谢。

如果觉得这篇文章不错,请点赞或分享到朋友圈吧!

如果喜欢的我的文章 ,欢迎关注我的公众号:点滴技术 ,扫码关注,不定期分享

文章来源于网络,如有侵权请联系站长QQ61910465删除
本文版权归趣快排www.sEoguruBlog.com 所有,如有转发请注明来出,竞价开户托管,seo优化请联系QQ✈61910465