调用数据库迁移命令中自带的auth_user

操作表

要调用此表需先导入二个方法
from django.contrib import auth
from django.contrib.auth.models import User
登录
auth.authenticate(request,username=username,password=password)
注:必须同时传入用户名与密码
注:此密码为密文格式

此命令拥有两个返回值
1.返回对象
在对象中可以查看对应信息(按数据库里的输出)
2.返回none

保存状态
auth.login(request,对象)
相当于request.session[key] = 对象
注:保存session
注:当执行这条方法时会自动存入django_session数据库中而且在任何地方都可以通过request.user获取当前登录的用户对象

判断是否登录
request.user,is_authenticated()
注:返回值为True或者False

获取当前用户登录名称
request.user

新旧密码比较
request.user.check_password(老密码)
注:自动加密且比对新老密码,返回值为True或者False

修改密码
request.user.set_password(新密码)
request.user.save()

注销
auth.logout(request)
注:消除session

自带的登录装饰器
from django.contrib.auth.decorators import login_required
@login_required(login_url=’/login/’)
注:该为局部配置,跳转带指定的页面

LOGIN_URL = ‘/login/’
@login_required
注:该为全局配置,没有值就往全局位置跳转

注册
User.objects.create_user(username=username,password=password)
注:此为注册普通用户,无需填入email
User.objects.create_superuser(username=username,email=‘123@qq.com’,password=password)
注:此为注册超级用户,不对外开放,需要填入eamil

注:以上两条存入数据库时 密码会自动转成密文格式(好像是sha256)

拓展表

class UserInfo(AbstractUser):
“”"
如果继承了AbstractUser
那么在执行数据库迁移命令的时候auth_user表就不会再创建出来了
而UserInfo表中会出现auth_user所有的字段外加自己扩展的字段
这么做的好处在于你能够直接点击你自己的表更加快速的完成操作及扩展

前提:
    1.在继承之前没有执行过数据库迁移命令
        auth_user没有被创建,如果当前库已经创建了那么你就重新换一个库
    2.继承的类里面不要覆盖AbstractUser里面的字段名
        表里面有的字段都不要动,只扩展额外字段即可
    3.需要在配置文件setting中告诉django你要用UserInfo替代auth_user(******)
        AUTH_USER_MODEL = 'app01.UserInfo'
                            '应用名.表名'
"""
phone = models.BigIntegerField()
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现将注册界面输入的用户名和密码存入auth_user,可以按照以下步骤进行操作: 1. 在django项目新建一个app,用于处理用户注册功能。 2. 在该app创建一个名为`views.py`的文件,用于处理用户注册请求。可以创建一个名为`register`的函数,接收`request`参数,处理用户注册请求。 3. 在`register`函数,需要先根据`request`参数获取用户输入的用户名和密码。 4. 调用Django提供的`User`模型的`create_user`方法,将用户名和密码存入`auth_user`库。可以在`models.py`文件导入`User`模型,然后在`register`函数调用`User`模型的`create_user`方法进行存储。 5. 如果注册成功,可以将用户重定向到登录页面或其他页面。如果注册失败,可以给用户提示错误信息。 下面是一个简单的代码示例: ```python # views.py from django.shortcuts import render, redirect from django.contrib.auth.models import User def register(request): if request.method == 'POST': # 获取用户输入的用户名和密码 username = request.POST.get('username') password = request.POST.get('password') # 将用户名和密码存入auth_user user = User.objects.create_user(username, password=password) user.save() # 注册成功后重定向到登录页面 return redirect('/login/') else: # 显示注册页面 return render(request, 'register.html') ``` 在上面的代码,`register`函数首先判断请求方法是否为`POST`,如果是则获取用户输入的用户名和密码。然后调用`User`模型的`create_user`方法,将用户名和密码存入`auth_user`库。最后重定向到登录页面。 需要注意的是,上面的代码只是一个简单的示例,实际开发还需要进行更多的错误处理和安全性检查。例如,需要验证用户名是否已被注册、密码是否符合要求等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值