首页>>后端>>Python->django如何限制同一帐号(django限制重复登录)

django如何限制同一帐号(django限制重复登录)

时间:2023-11-29 本站 点击:0

今天给各位分享django如何限制同一帐号的知识,其中也会对django限制重复登录进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

1、django1.9.5怎么建立超级用户2、如何限制Django模型中数值字段的最大值3、django如何实现管理员只能登录后台,不能登录前台网站?4、django1.9.5怎么建立超级用户?5、如何在Django模型中管理并发性6、Django django-allauth 实现第三方授权登陆平台(百度和github为例)

django1.9.5怎么建立超级用户

首先我们要新建一个用户名,用来登陆管理网站,可以使用如下命令:

python manage.py createsuperuser

输入想要使用的用户名:

Username (leave blank to use 'administrator'): user01

输入email:

Email address: (在这里输入你的自己的邮箱帐号)

输入密码,需要输入两次,并且输入密码时不会显示出来:

Password:

Password (again):

当两次密码都相同的时候,就会提示超级帐号创建成功。

Superuser created successfully.

运行服务:

python manage.py runserver

如何限制Django模型中数值字段的最大值

有两种方法可以做到这一点。 一个是使用表单验证从不允许用户输入超过 50的数字。 表单验证文档 。

如果进程中没有用户,或者你没有使用表单输入数据,那么你必须重写模型方法的save,或者将数据限制在字段中。

django如何实现管理员只能登录后台,不能登录前台网站?

这个建议后台弄个权利管理模块,这样就可以控制不同账号只能登录的权限啦

django1.9.5怎么建立超级用户?

首先我们要新建一个用户名,用来登陆管理网站,可以使用如下命令:\x0d\x0apython manage.py createsuperuser\x0d\x0a输入想要使用的用户名:\x0d\x0a\x0d\x0aUsername (leave blank to use 'administrator'): user01\x0d\x0a输入email:\x0d\x0a\x0d\x0aEmail address: (在这里输入你的自己的邮箱帐号)\x0d\x0a输入密码,需要输入两次,并且输入密码时不会显示出来:\x0d\x0a\x0d\x0aPassword:\x0d\x0aPassword (again):\x0d\x0a当两次密码都相同的时候,就会提示超级帐号创建成功。\x0d\x0aSuperuser created successfully.\x0d\x0a\x0d\x0a运行服务:\x0d\x0a\x0d\x0apython manage.py runserver

如何在Django模型中管理并发性

1、我们在我们的查询器上使用select_for_update来告诉数据库锁定对象,直到事务完成。

2、在数据库中锁定一行需要一个数据库事务 - 我们使用Django的装饰器transaction.atomic来定义事务。

3、我们使用类方法而不是实例方法 - 我们告诉数据库要上锁,然后它会返回锁的对象给我们。 为了实现这一点,我们需要从数据库中获取对象。 如果我们使用self,那么就是在操作一个已经从数据库中获取出来的对象,这个对象无法保证自己是没有被上锁的。

4、帐户中的所有操作都在数据库事务中执行。

Django django-allauth 实现第三方授权登陆平台(百度和github为例)

 在浏览器中输入 查看

 页面比较简陋,可以在 allauth/templates 目录中进行修改,测试的话就比较随意啦。在登陆页面中,可以直接使用帐号密码进行登陆,帐号密码需要注册,点击 Sign Up 进行注册

 这里有个问题需要注意一下,在填写完表单之后点击注册按钮,会返回一个 ConnectionRefusedError 的错误页面,allauth 在注册用户时,会给用户填写的邮箱发送一封激活邮件,而这里并没有配置好邮箱系统,所以发送失败。需要进行一下配置

 django 默认发送邮件的后端是 smtp

 之后注册成功就会在填写的邮箱中收到一封激活邮件(找不到可以在垃圾箱中看一下),点击连接可以激活帐号,也可以在配置的邮箱帐号中查看已发送的邮箱。

 注册成功之后会自动登陆该帐号,登陆成功 django 会将页面跳转到 ,返回的是一个 Page not found 的页面,因为这个视图还没有编写。怎么解决?方法有两个,第一自己动手编写这个视图,第二,更改 django 登陆成功后重定向的 url。

 django 默认重定向的 url 是 /accounts/profile/,setting.py中可以修改

 再次登陆 就会跳转到 /accounts/inactive/ 页面

 在 中新建一个 OAuth Apps

 这里要注意一下 Authorization callback URL 的填写,必须是 /accounts/github/login/callback/ 结尾,前面则和 Homepage URL 一样,创建成功之后会得到一个 Client ID 和一个 Client Secret (基于 OAuth 协议),通过这连个值,可以获得授权。

 allauth 支持多种第三方账户登陆,只需要在 settings.py 中的 INSTALLED_APPS 注册需要哦应用就可以了

  更多应用可以查看文档

 创建超级用户之后进入

 点击 Sites 将 exampple.com 修改为

 直接打开登陆页面 如果超级用户账户还在登陆的话,会跳转到之前设置的 /accounts/inactive/ 页面,直接点击 Sign Out 注销登陆,再次打开登陆页面

 点击 Github,因为之前在 Github 网站上创建 OAuth apps 时已经登陆了账户,所以会自动授权登陆,不然就会要求输入账户密码

或者

 百度登陆和 Github 差不多,也是需要在 百度开发者中心 创建一个应用获取两个 key

 这里还要填写好授权回调页

 和之前 Github 一样,但是注意 Provider 一项要选择 Baidu

esmp;增加 Social applications 之后就可以在登陆页面找到 Baidu 的登陆按钮

 新浪微博和腾讯QQ需要用到身份证审核,恰好最近身份证过期拿去更换,申请不了,只能下次在完成

关于django如何限制同一帐号和django限制重复登录的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


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