Django如何实现简单登录

Django如何实现简单登录

这篇文章主要为大家展示了“Django如何实现简单登录”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Django如何实现简单登录”这篇文章吧。

创建django项目

创建项目的命令行语句: django-admin startproject newsManage

将templates文件放在模板里面,会显得更简洁一些,所以我就先创建模板啦。

命令行语句:django-admin startapp newsModel

创建好模型把模型名加到setting文件下 INSTALLED_APPS 里面 , 不然到时候会报错说找不到的

创建templates目录,来存放html,js,css等文件,在setting文件下 TEMPLATES 配置templates的文件路径 'DIRS': [os.path.join(BASE_DIR, 'templates')],

最后大致的目录结构就是这样了

使用模型的url.py

创建项目的时候会自带一个urls.py文件,是用来配置路径的,都写在一个urls里面会显得比较乱,放在模板里面就完美的解决了这个问题

路径:newsManage/newsManage/urls.py

urlpatterns=[path('admin/',admin.site.urls),path('',include('newsModel.urls'))]

在newsModel模板下创建urls.py文件 路径:newsManage/newsModel/urls.py

fromdjango.urlsimportpathfrom.importviewsurlpatterns=[path('',views.login,name='login')]

路径:newsManage/newsModel/views.py

deflogin(request):returnrender(request,'login.html')

在templates下创建login.html文件,然后写登录页面(用模板也太香了吧)
运行启动服务器 python manage.py runserver

加载静态文件

static就是放静态文件的像 css,js 加载静态文件也需要配置,setting最后一行加上

STATICFILES_DIRS=[os.path.join(BASE_DIR,"static")]

在html里面引用,需要在前面加上{% load static %}
然后就可以引用了 <link href="{% static 'css/style.css' %}" rel="external nofollow" rel="stylesheet">

页面跳转

path('/register',views.register,name='register')

像上面这个注册的url,可以通过路径 或者 name 跳转

<aclass="text-primary"href="{%url'register'%}"rel="externalnofollow">Signup</a>

点击这个链接就可以跳转到注册页面啦

创建数据库模型

在 newsManage/newsManage/init.py 配置pymysql, 没有下载的话需要去下载pymysql

importpymysqlpymysql.install_as_MySQLdb()

路径:newsManage/newsModel/models.py(类名就是表名)

classuser(models.Model):username=models.CharField(max_length=30)password=models.CharField(max_length=30)email=models.EmailField(unique=True,blank=False)

运行命令行,生成表结构

pythonmanage.pymigratepythonmanage.pymakemigrationspythonmanage.pymigratenewsModel

数据库的表名就是 模型名_类名( newsModel_user )
admin/ 路径是可以直接在浏览器上操作数据库的

提交

表单提交

后台判断登录是否成功

deftoLogin(request):ifrequest.method=='POST':username=request.POST.get("username")password=request.POST.get("password")users=user.objects.all()foruinusers:ifu.username==usernameandu.password==password:returnredirect("home")context={"msg":"用户名或密码错误!"}returnrender(request,"login.html",context)

ajax提交

data=eval("("+data+")");灰常重要,记得转换一下,不然取不到,但好像别人不用转也可以。。。。$.ajax({type:'POST',url:"{%url'toLoginByAjax'%}",data:{'username':$("#username").val(),'password':$("#password").val()},dataType:'text',success:function(data){data=eval("("+data+")");if(data.code==0){window.location.href="{%url'home'%}"}else{$(".msg").html(data.msg);setTimeout(function(){//定时器$(".msg").css("display","none");//将图片的display属性设置为none},3000);//设置三千毫秒即3秒}},error:function(){console.log("somewhereiswrong")}})deftoLoginByAjax(request):username=request.POST.get("username")password=request.POST.get("password")users=user.objects.all()foruinusers:ifu.username==usernameandu.password==password:message={"code":0,"msg":"登陆成功!"}returnJsonResponse(message)message={"code":400,"msg":"登陆失败,用户名或密码错误!"}returnJsonResponse(message)

就可以成功登录到主页(home.html)啦!

以上是“Django如何实现简单登录”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注恰卡编程网行业资讯频道!

发布于 2022-03-03 21:24:01
收藏
分享
海报
0 条评论
43
上一篇:C语言如何实现银行ATM存取款系统 下一篇:Flask如何实现请求钩子
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码