09.用户认证auth模块

用户认证auth模块

01.auth模块
  from django.contrib import auth

<1>authenticate()
提供了用户认证,即验证用户名以及密码是否正确,一般需要username password两个关键字参数
如果认证信息有效,会返回一个 User 对象,失败返回None
user = authenticate(username='someone',password='somepassword')

<2>login(HttpRequest, user)  
该函数接受一个HttpRequest对象,以及一个认证了的User对象
此函数使用django的session框架给某个已认证的用户附加上session id等信息。
auth.login(request, user) # 必写!!!!!request.user==当前登陆对象,全局使用

<3>logout(request) 注销用户
auth.logout(request) # 相当于request.session.flush()删掉此次session


02.User对象

  <1>user对象的 is_authenticated()
  如果是真正的 User 对象,返回值恒为 True 。 用于检查用户是否已经通过了认证。

<2>装饰器@login_required
应用场景:
1 用户登陆后才能访问某些页面,
2 如果用户没有登录就访问该页面的话直接跳到登录页面
3 用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址

from django.contrib.auth.decorators import login_required

@login_required
def my_view(request):
...
若用户没有登录,则会跳转到django默认的 登录URL '/accounts/login/ '
(这个值可以在settings文件中通过LOGIN_URL = "/login/"进行修改)。
并传递 当前访问url的绝对路径 (登陆成功后,会重定向到该路径)。

<3>创建用户create_user
使用 create_user 辅助函数创建用户:
from django.contrib.auth.models import User
user = User.objects.create_user(username='',password='',email='')

<4>check_password(passwd)
用户需要修改密码的时候 首先要让他输入原来的密码 ,
如果给定的字符串通过了密码检查,返回 True

<5>修改密码
使用 set_password() 来修改密码

user = User.objects.get(username='')
user.set_password(password='')
user.save

转载于:https://www.cnblogs.com/QQL-anatkh/p/9597644.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django框架的用户认证模块可以帮助开发者轻松地实现用户注册、登录、登出等功能。下面是一个简单的示例: 1. 配置settings.py文件 首先需要在settings.py文件中配置以下代码: ```python INSTALLED_APPS = [ # ... 'django.contrib.auth', 'django.contrib.contenttypes', # ... ] AUTH_USER_MODEL = 'myapp.CustomUser' # 自定义用户模型 LOGIN_REDIRECT_URL = 'home' # 登录成功后重定向到该URL LOGOUT_REDIRECT_URL = 'home' # 登出成功后重定向到该URL ``` 2. 创建自定义用户模型 在models.py文件中创建自定义用户模型: ```python from django.contrib.auth.models import AbstractUser class CustomUser(AbstractUser): # 添加自定义字段 pass ``` 3. 创建注册视图 在views.py文件中创建注册视图: ```python from django.contrib.auth.forms import UserCreationForm from django.urls import reverse_lazy from django.views import generic class SignUpView(generic.CreateView): form_class = UserCreationForm success_url = reverse_lazy('login') template_name = 'signup.html' ``` 4. 创建登录视图 在views.py文件中创建登录视图: ```python from django.contrib.auth.views import LoginView class MyLoginView(LoginView): template_name = 'login.html' ``` 5. 创建登出视图 在views.py文件中创建登出视图: ```python from django.contrib.auth.views import LogoutView class MyLogoutView(LogoutView): template_name = 'logout.html' ``` 6. 创建模板 在templates文件夹中创建signup.html、login.html和logout.html模板文件。 7. 配置URL 在urls.py文件中配置以下代码: ```python from django.urls import path from .views import SignUpView, MyLoginView, MyLogoutView urlpatterns = [ # 注册 path('signup/', SignUpView.as_view(), name='signup'), # 登录 path('login/', MyLoginView.as_view(), name='login'), # 登出 path('logout/', MyLogoutView.as_view(), name='logout'), ] ``` 以上是一个简单的Django用户认证模块的示例,可以根据具体需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值