五.数据库同步,创建django用户,用户登陆过程
(1)配置数据库
项目目录/settings.py是一个普通的python模块,每项配置都是一key/value
数据库的配置是以dict的形式存放在这个模块中,key名为:DATABASES DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django',
'USER': 'root',
'PASSWORD': '',
'HOST': '127.0.0.1',
'PORT': 3306,
}
}
(python36env) [vagrant@CentOS7 devops]$ python manage.py makemigrations
No changes detected
(python36env) [vagrant@CentOS7 devops]$ python manage.py dbshell 进入数据库查看数据
MariaDB [devops]> show tables; --可以看到直接进入devops库了
(python36env) [vagrant@CentOS7 devops]$ python manage.py runserver 0.0.0.0:8000
(3)创建用户:
a.使用django shell 创建普通用户:创建users最直接的方法是使用create_user()辅助函数
(python36env) [vagrant@CentOS7 devops]$ python manage.py shell
In [1]: from django.contrib.auth.models import User 导入User类
In [2]: User.objects.create_user("rock","rock@51reboot.com","123456") 创建用户
b.也可通过命令行创建:创建管理员
(python36env) [vagrant@CentOS7 devops]$ python manage.py createsuperuser
Username (leave blank to use 'vagrant'): admin
Email address: admin@51reboot.com
Password:123456
(4)修改密码
MariaDB [devops]> show tables;
+----------------------------+
| Tables_in_devops |
+----------------------------+
| auth_user |
MariaDB [devops]> select * from auth_user \G ---用格式化查看此表
修改密码:
(python36env) [vagrant@CentOS7 devops]$ python manage.py shell 进入django的shell环境
In [1]: from django.contrib.auth.models import User 导入User类
In [2]: User.objects.get(username="rock") 查询用户并保存在一个U用户对象中
In [3]: u = User.objects.get(username="rock")
In [4]: u.set_password("654321") 用户对象的set_password属性
In [5]: u.save 保存
还可通过命令行进行修改。
二.用户登陆
1.简单应用:
(1)写视图
from django.shortcuts import render
def user_login(request):
return render(request, 'user_login.html')
(2)写模版文件user_login.html: ---写一简单炫表单
<body>
<ul>
<form method="get" action="#"> ----action为#是本机即当前地址
<li>用户名: <input type="text" name="username"></li>
<li>密码: <input type="password" name="password"></li>
<li>用户名: <input type="submit"></li>
<li>rock 654321</li>
<li>admin 123456</li>
</form>
</ul>
</body>
(3)配置url
from django.conf.urls import include, url
from .views import index, index_template, user_login
urlpatterns = [
url(r'^user_login/', user_login)
]
启动后效果如下:

它有两种请求:get和post
2.get请求:
(1)如下图中输入用户名密码点提交(也可直接在url地址中输入)后会在浏览器url中显示出来提交的数据,直接发给后端

(2)后端拿到数据:
def user_login(request):
print(request.GET) #拿到前端传的数据
return render(request, 'user_login.html')
如下图终端:拿到数据

(3)后端处理:
#1.获取用户提交过来的用户名
#2.根据用户名从数据库里取此条记录是否存在
#2.1不存在
#2.2存在,则判断密码是否一致,一致则登录成功(注意用户提交过来的密码是明文,而后端能拿到的是密文,而明文与密文没法直接比,需要对用户明文加密转码)
views.py中:
from django.contrib.auth.models import User
from django.contrib.auth import login,logout,authenticate
def user_login(request):
print(request.GET) #拿到前端传的数据
#1.获取提交过来的用户名
username = request.GET.get("username")
password = request.GET.get("password")
#验证用户密码
user_obj = authenticate(username=username, password=password)
if user_obj:
login(request, user_obj) #验证成功则登录
print("登录成功")
else:
print("登录失败")
return render(request, 'user_login.html')
效果如下图:登录成功后

上图中可看到有一sessionid,和如下数据库中django_session表中session-key一样,即我们就是根据用户的cookie,cookie中存放了sessionid,sessionid就是django_session表中的key,然后session_data就可以反转成我们用户的数据/用户对象
(python36env) [vagrant@CentOS7 devops]$ python manage.py dbshell
MariaDB [devops]> show tables;
MariaDB [devops]> select * from django_session \G
*************************** 1. row ***************************
session_key: e59z6132h583m2ci097wovnt5srws4r2
session_data: NjkxMDkyYWFlMmU2ZWQ2NWEyOWZkNTRjZWU3ZTE4ZDQxZGQzZDliNDp7Il9hdXRoX3VzZXJfaWQiOiIyIiwiX2F1dGhfdXNlcl9iYWNrZW5kIjoiZGphbmdvLmNvbnRyaWIuYXV0aC5iYWNrZW5kcy5Nb2RlbEJhY2tlbmQiLCJfYXV0aF91c2VyX2hhc2giOiIzYTE2NDhkNTkyYmJlMGMwNTAyOTUwZGVhNWUxNGMzN2E3MzFjMjcwIn0=
3.post请求:
(1)templates/user_login.html修改如下部分:
<body>
<ul>
<form method="post" action="#">
.....
(2)views.py:
为调试,我先把settings.py中csrftoken中间件注释掉
def user_login(request):
if request.method == "GET":
return render(request, 'user_login.html')
elif request.method == "POST":
username = request.POST.get("username")
password = request.POST.get("password")
#验证用户密码
user_obj = authenticate(username=username, password=password)
if user_obj:
login(request, user_obj) #验证成功则登录
print("登录成功")
else:
print("登录失败")
return HttpResponse("")
效果如下图:登录成功后form data它就是querydict的原始数据,即request.POST就等于QueryDict(request.body)

4.那问题来了,如果是request.methon == "DELETE"方法做用户登录?
(1)templates/user_login.html:修改如下部分
<ul>
<form method="DELETE" action="#">
......
(2)views.py:
def user_login(request):
if request.method == "GET":
return render(request, 'user_login.html')
elif request.method == "POST":
username = request.POST.get("username")
password = request.POST.get("password")
#验证用户密码
user_obj = authenticate(username=username, password=password)
if user_obj:
login(request, user_obj) #验证成功则登录
print("登录成功")
else:
print("登录失败")
elif request.method == "DELETE":
print(request.GET)
print(request.POST)
print("delete") return HttpResponse("")
模拟delete请求如下:如下图中delete请求过来了(get,post请求没有)那数据中哪里呢?
(python36env) [vagrant@CentOS7 devops]$ curl -XDELETE http://127.0.0.1:8000/dashboard/user_login/ -d username=rock -d password=123456

数据都放在:
那怎样拿到delete请求方法的数据如下:
elif request.method == "DELETE":
data = QueryDict(request.body) ---这样就拿到了
print(request.GET)
print(request.POST)
print(request.body)
print(data)
print("delete")
效果如下图:

五.数据库同步,创建django用户,用户登陆过程的更多相关文章
- 在mysql数据库中创建oracle scott用户的四个表及插入初始化数据
在mysql数据库中创建oracle scott用户的四个表及插入初始化数据 /* 功能:创建 scott 数据库中的 dept 表 */ create table dept( deptno int ...
- 0004 继承django系统用户表
1 创建基础模型 在本项目中,所有表都有两个自动产生的完全相同的字段,即创建时间和更新时间,因此,可以创建一个基础模型,让所有的表都来继承这个模型. 找到工程目录下的PublicMethod目录,创建 ...
- Redis & Python/Django 简单用户登陆
一.Redis key相关操作: 1.del key [key..] 删除一个或多个key,如果不存在则忽略 2.keys pattern keys模式匹配,符合glob风格通配符,glob风格的通配 ...
- mysql 创建数据库,添加用户,用户授权
一.创建mysql数据库 1.创建数据库语法 --创建名称为"testdb"数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb ...
- 数据库迁移到Azure SQL Database用户无法登陆的问题
业务情景:数据库是运维迁移上去的,好像使用了一个工具叫做Microsoft Data Migration Assistant,迁移之后,我的web应用无法连接数据库. 迁移之后的数据库内有User,但 ...
- 运维开发笔记整理-创建django用户
运维开发笔记整理-创建django用户 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.创建普通用户 C:\Users\yinzhengjie\softwares\Pycharm ...
- aud$定位错误用户密码登陆数据库的具体信息
环境:Oracle 11.2.0.3 客户端使用错误的用户密码登陆数据库 查询最近1天由于密码错误登陆失败的信息 查询当前审计中有哪些returncode值 1. 客户端使用错误的用户密码登陆数据库 ...
- Oracle数据库之创建表空间与用户
Oracle数据库之创建表空间与用户 一.创建表空间 基本语法表述: CREATE TABLESPACE tablespace_name [DATAFILE datafile_spec1 [,data ...
- Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据
基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...
随机推荐
- Java实现 蓝桥杯VIP 算法训练 简单加法
时间限制:1.0s 内存限制:512.0MB 问题描述 首先给出简单加法算式的定义: 如果有一个算式(i)+(i+1)+(i+2),(i>=0),在计算的过程中,没有任何一个数位出现了进位,则称 ...
- Java实现 洛谷 P1487 陶陶摘苹果(升级版)
题目描述 又是一年秋季时,陶陶家的苹果树结了n个果子.陶陶又跑去摘苹果,这次她有一个a公分的椅子.当他手够不着时,他会站到椅子上再试试. 这次与NOIp2005普及组第一题不同的是:陶陶之前搬凳子,力 ...
- Java实现微生物增殖
微生物增殖 假设有两种微生物 X 和 Y X出生后每隔3分钟分裂一次(数目加倍),Y出生后每隔2分钟分裂一次(数目加倍). 一个新出生的X,半分钟之后吃掉1个Y,并且,从此开始,每隔1分钟吃1个Y. ...
- Spring MVC详细讲解
一:三层架构和MVC 1:三层架构 我们的开发架构一般都是基于两种形式:一种是 C/S 架构,也就是客户端/服务器,另一种是 B/S 架构,也就是浏览器服务器.在 JavaEE 开发中,几乎全都是基于 ...
- 痞子衡嵌入式:降低刷新率是定位LCD花屏显示问题的第一大法(i.MXRT1170, 1280x480 LVDS)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是i.MXRT1170上LCD花屏显示问题的分析解决经验. 痞子衡最近这段时间在参与一个基于i.MXRT1170的大项目(先保个密),需要 ...
- 移除VS解决方案中的TFS版本控制
项目每次会弹出提示 正在打开的解决方案已绑定到以下 Azure DevOps Server 上的源代码管理: xxxxx.是否要联系此服务器以尝试启用源代码管理集成? 移除VS解决方案中的TFS版本控 ...
- Redis之分布式锁实现
点赞再看,养成习惯,微信搜索[三太子敖丙]关注这个互联网苟且偷生的工具人. 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试完整考点.资料以及我的 ...
- Grafana 插件地图Worldmap不显示
介绍 最近上了ELK 日志分析,想着手看下用户的分布情况,在kibana 中展示用户分布情况是没有问题的,但是索引添加到Granfana 中的话就无法展示. 问题描述 添加ES索引以后,map地图一片 ...
- 第一章02-异常情况下Activity的生命周期
异常情况下的生命周期分析 1. 资源相关的系统配置发生改变导致Activity被杀死并重新创建 比如,屏幕旋转,默认情况下Activity会被销毁并且重新创建,不过我们也可以阻止系统重新创建我们的Ac ...
- 介绍几种给你的Python代码加上酷炫的进度条的方式
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 大家好,在下载某些文件的时候你一定会不时盯着进度条,在写代码的时候使用进度 ...