Django之登录权限系统

本文参考链接django之auth模块(用户认证) - chchcharlie、 - 博客园 (cnblogs.com)

执行完迁移命令,会自动生成admin表,迁移命令如下:

python manage.py makemigrations

python manage.py migrate

 相关模块

from django.contrib import auth  # 导入auth模块,用于鉴权
from django.contrib.auth.models import User  # 导入auth_user表对象,用于创建用户
from django.contrib.auth.decorators import login_required  # 校验用户是否登陆的装饰器

 1)注册创建用户

User.objects.create(username=username, password=password)  # 创建普通用户,密码不加密(不推荐使用)
User.objects.create_user(username=username, password=password)  # 创建普通用户,密码加密(推荐使用)
User.objects.create_superuser(username=username, password=password, email='123@qq.com')  # 创建超级用户,但是必须填写邮箱事项,要不报错

 举例 用户注册代码

def register_action(request):u_name = request.GET['username']p_word = request.GET['password']# 开始 联通django用户表from django.contrib.auth.models import Usertry:user = User.objects.create_user(username=u_name,password=p_word)user.save()return HttpResponse('注册成功!')except:return HttpResponse('注册失败~用户名好像已经存在了~')

2)登录验证用户

auth.authenticate(request, username=username, password=password) # 用户名密码正确返回的是用户对象,错误返回None

 auth.login(request, user_obj) 

# 只要执行了此代码,之后在任意可以获取到request对象的地方,都可以通过request.user获取到当前登录的用户对象

 request.user.is_authenticated() # 判断是否登陆 request.user # 登陆用户对象

举例用户登录代码

def login_action(request):u_name = request.GET['username']p_word = request.GET['password']# 开始 联通 django 用户库,查看用户名密码是否正确from django.contrib import authuser = auth.authenticate(username=u_name,password=p_word)if user is not  None:# 进行正确的动作auth.login(request, user)  # 不写这个加了@login_required,就登录不了了,也添加了sessionrequest.session['user'] = u_name  # 这个是设置session,上面已经添加了,这个没有用return HttpResponse('成功')else:# 返回前端告诉前端用户名/密码不对return HttpResponse('失败')

 3)修改密码

# 先校验旧密码是否正确
request.user.check_password(old_password)  # 返回的是布尔值
# 修改密码
request.user.set_password(new_password)
request.user.save()  # 一定要保存

 4)注销登录

auth.logout(request)

举例用户注销

# 注销
def logout(request):from django.contrib import authauth.logout(request)return HttpResponseRedirect('/login/')

 5)校验用户是否登陆,未登录情况下自动跳转到自定义的登录界面

@login_required
def welcome(request):print('进来了')# return HttpResponse('欢迎来到主页')return render(request,'welcome.html')
path('accounts/login/', login),  # 未注册重定向

使用auth模块写一个注册、登陆、修改密码、注销登陆功能 

from django.contrib import auth  # 导入auth模块
from django.contrib.auth.models import User  # 导入auth_user表对象
from django.contrib.auth.decorators import login_required  # 校验用户是否登陆的装饰器# 注册功能
def register(request):if request.method == 'POST':username = request.POST.get('username')password = request.POST.get('password')User.objects.create_user(username=username, password=password) return HttpResponse('注册成功!')return render(request, 'register.html')# 登录功能
def login(request):if request.method == 'POST':username = request.POST.get('username')password = request.POST.get('password')# 数据库校验用户名和密码是否正确user_obj = auth.authenticate(request, username=username, password=password)# print(res)  # 用户名密码正确返回的是用户对象,错误返回Noneif user_obj:# 保存用户登录状态auth.login(request, user_obj)return HttpResponse('登陆成功!')return render(request, 'login.html')# 登陆之后可以查看的页面
@login_required
def get_user(request):print(request.user)print(request.user.is_authenticated)return HttpResponse('get_user页面')# 登陆之后可以查看的页面
@login_required
def login_after01(request):return HttpResponse('我是login_after01页面')# 登陆之后可以查看的页面
@login_required
def login_after02(request):return HttpResponse('我是login_after02页面')# 登陆之后可以查看的页面
@login_required
def login_after03(request):return HttpResponse('我是login_after03页面')# 修改密码功能
@login_required
def set_password(request):if request.method == 'POST':old_password = request.POST.get('old_password')new_password = request.POST.get('new_password')# 先校验旧密码是否正确is_right = request.user.check_password(old_password)  # 返回的是布尔值# 再修改密码if is_right:request.user.set_password(new_password)request.user.save()  # 一定要保存return render(request, 'set_password.html')# 注销功能
@login_required
def logout(request):auth.logout(request)return HttpResponse('注销成功')

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

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

相关文章

敏感词匹配DFA算法

算法简介与场景介绍 DFA算法,中文全称为确定性有穷自动机。它的基本思想是构建一个有穷自动机,当用户输入文本时,通过自动机的状态转换来快速匹配敏感词。具体特征是,有一个有效状态的集合和一些从一个状态通向另一个状态的边&am…

大模型面试(二)

这次又接到一个大模型岗位的面试。但是从面试过程来看,现在大模型岗位都要求有相关工作经验,还是太难进了。还是说国内公司早就过了培养人的年代了? 问到了哪些知识点: 开源大模型:项目里用的是浦语大模型&#xff0…

VuePress 的更多配置

现在,读者应该对 VuePress、主题和插件等有了基本的认识,除了插件,VuePress 自身也有很多有用的配置,这里简单说明下。 ‍ ‍ VuePress 的介绍 在介绍了 VuePress 的基本使用、主题和插件的概念之后,我们再来看看官…

简介空间复杂度

我们承接上一篇博客。我们写了时间复杂度之后,我们就要来介绍一下另一个相关复杂度了。空间复杂度。我觉得大家应该对空间复杂度认识可能比较少一些。我就是这样,我很少看见题目中有明确要求过空间复杂度的。但确实有这个是我们不可忽视的,所…

PXIe-7976【K410T】

起售价 RMB 152,880.00 块RAM(BRAM): 28620 kbit 动态RAM(DRAM): 2 GB FPGA: Kintex-7 410T PXI背板链路: PCI-Express Gen2 x 8 FPGA片: 63550 DSP片: 1540

文本关系抽取实战

数据与源码地址见文末 1.文本关系抽取要完成的任务 文本关系抽取是自然语言处理领域的一个重要任务,其主要目的是从非结构化的文本数据中自动识别和提取出实体之间的关系。这个过程可以分为以下几个关键步骤和目标: 实体识别:首先需要识别出文本中的关键实体,这些实体可以…

ChatGPT-4o大语言模型优化、本地私有化部署、从0-1搭建、智能体构建等高级进阶

目录 第一章 ChatGPT-4o使用进阶 第二章 大语言模型原理详解 第三章 大语言模型优化 第四章 开源大语言模型及本地部署 第五章 从0到1搭建第一个大语言模型 第六章 智能体(Agent)构建 第七章 大语言模型发展趋势 第八章 总结与答疑讨论 更多应用…

昇思25天学习打卡营第12天|FCN图像语义分割

文章目录 昇思MindSpore应用实践基于MindSpore的FCN图像语义分割1、FCN 图像分割简介2、构建 FCN 模型3、数据预处理4、模型训练自定义评价指标 Metrics 5、模型推理结果 Reference 昇思MindSpore应用实践 本系列文章主要用于记录昇思25天学习打卡营的学习心得。 基于MindSpo…

LaTeX教程(014)-LaTeX文档结构(14)

LaTeX教程(014)- LaTeX \LaTeX LATE​X文档结构(14) 2.3.3 multitoc - 将目录设置为多栏 multitoc包的使用方法相当简单,只需要调用这个包,并将要设置为多栏(默认是双栏)的目录指定到包选项中即可。如\usepackage[toc]{multitoc},设置的就是…

[python技巧]OmegaConf调用配置文件

在https://blog.csdn.net/qq_43235540/article/details/140250813?spm1001.2014.3001.5502中介绍了parser的使用方法,一般传入参数和是配置文件一起使用,配置. OmegaConf.load() 从.yaml文件读取配置 opt, unknown parser.parse_known_args() configs [OmegaConf.load(cf…

Springboot使用WebSocket发送消息

1. 创建springboot项目&#xff0c;引入spring-boot-starter-websocket依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency>完整项目依赖 <?xml ver…

Vue 使用 @click 绑定点击事件

https://andi.cn/page/621505.html

Python【打包exe文件两步到位】

Python打包Exe 安装 pyinstaller&#xff08;pip install pyinstaller&#xff09; 执行打包命令&#xff08;pyinstaller demo.py&#xff09; 打完包会生成 dist 文件夹&#xff0c;如下如

基于开源AI数据框架LlamaIndex构建上下文增强型LLA应用

引言 “将你的企业数据转化为可用于实际生产环境的LLM应用程序&#xff0c;”LlamaIndex主页用60号字体这样高亮显示。其副标题是“LlamaIndex是构建LLM应用程序的领先数据框架。”我不太确定它是否是业内领先的数据框架&#xff0c;但我认为它是一个与LangChain和Semantic Ker…

快行线冷链——创新仓配、共赢未来 主题沙龙在京成功举办

2024年7月7日下午&#xff0c;由京营建联盟、北京市大兴区餐饮行业协会、北京快行线冷链物流联合主办的“创新仓配&#xff0c;共赢未来——相信拥抱的力量”主题沙龙活动在北京篝野城市露营空间隆重举行。本次活动定向邀请了餐饮老板、餐饮企业供应链负责人及冻品经销商和相关…

电子电气架构 --- 智能座舱万物互联

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

SpringSecurity在SpringBoot中的自动装配

从SpringBoot的自动装配原理入手 找到META-INFO下的spring.factories文件 SpringSecurity作为Spring的亲儿子&#xff0c;自然在spring-boot-autoconfigure下的spring.factories文件中配置了 org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfigurat…

C语言指针函数指针

跟着这篇文章重新理解了一下&#xff1a;彻底攻克C语言指针 有一个例子感觉可以拿出来看看&#xff1a; char *(*c[10])(int **p); * 这段声明定义了一个长度为10的数组c&#xff0c;数组中的每个元素都是指向函数的指针。每个函数接受一个类型为int **&#xff08;指向指向…

拆分Transformer注意力,韩国团队让大模型解码提速20倍|大模型AI应用开始小规模稳步爆发|周伯文:大模型也有幻觉,全球AI创新指数公布

拆分Transformer注意力&#xff0c;韩国团队让大模型解码提速20倍AI正在颠覆AI上市不到两年&#xff0c;蜗牛游戏可能要退市了&#xff1f;世界人工智能大会结束了&#xff0c;百花齐放&#xff0c;但也群魔乱舞“串联OLED”被苹果带火了&#xff0c;比OLED强在哪里&#xff1f…

API-案例-放大镜效果

学习目标&#xff1a; 掌握案例-放大镜效果 学习内容&#xff1a; 业务分析思路分析放大镜完整代码 业务分析&#xff1a; 鼠标经过对应小盒子&#xff0c;左侧中等盒子显示对应中等图片&#xff1b;鼠标经过中盒子&#xff0c;右侧会显示放大镜效果的大盒子&#xff1b;黑色…