十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶(hù) + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專(zhuān)業(yè)推廣+無(wú)憂(yōu)售后,網(wǎng)站問(wèn)題一站解決
這篇文章主要介紹“django實(shí)現(xiàn)賬號(hào)密碼驗(yàn)證登陸功能”,在日常操作中,相信很多人在django實(shí)現(xiàn)賬號(hào)密碼驗(yàn)證登陸功能問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”django實(shí)現(xiàn)賬號(hào)密碼驗(yàn)證登陸功能”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
發(fā)展壯大離不開(kāi)廣大客戶(hù)長(zhǎng)期以來(lái)的信賴(lài)與支持,我們將始終秉承“誠(chéng)信為本、服務(wù)至上”的服務(wù)理念,堅(jiān)持“二合一”的優(yōu)良服務(wù)模式,真誠(chéng)服務(wù)每家企業(yè),認(rèn)真做好每個(gè)細(xì)節(jié),不斷完善自我,成就企業(yè),實(shí)現(xiàn)共贏。行業(yè)涉及衛(wèi)生間隔斷等,在成都網(wǎng)站建設(shè)、全網(wǎng)營(yíng)銷(xiāo)推廣、WAP手機(jī)網(wǎng)站、VI設(shè)計(jì)、軟件開(kāi)發(fā)等項(xiàng)目上具有豐富的設(shè)計(jì)經(jīng)驗(yàn)。
今天分享一下django的賬號(hào)密碼登陸,前端發(fā)送ajax請(qǐng)求,將用戶(hù)名和密碼信息發(fā)送到后端處理,后端將前端發(fā)送過(guò)來(lái)的數(shù)據(jù)跟數(shù)據(jù)庫(kù)進(jìn)行過(guò)濾匹配,成功就跳轉(zhuǎn)指定頁(yè)面,否則就把相對(duì)應(yīng)的錯(cuò)誤信息返回,同時(shí)增加一個(gè)小功能,在規(guī)定時(shí)間內(nèi)超過(guò)規(guī)定的登錄次數(shù),就鎖住無(wú)法登陸,等下一個(gè)時(shí)間段再允許登陸。
一、通過(guò)ORM創(chuàng)建一張歷史登陸表
class login_history(models.Model): user = models.CharField(max_length=32, verbose_name='登錄用戶(hù)') ip = models.GenericIPAddressField(verbose_name='用戶(hù)IP地址') count = models.SmallIntegerField(verbose_name='登錄次數(shù)') lock = models.SmallIntegerField(verbose_name='鎖') utime = models.DateTimeField(auto_now=True, verbose_name='更新時(shí)間') class Meta: db_table = "login_history" verbose_name = "歷史登錄" verbose_name_plural = "歷史登錄" def __str__(self): return self.user
二、前端圖片跟代碼展示
前端代碼
- 登錄 {% include 'css_comm.html' %}{% include 'js_comm.html' %}歡迎使用 AutoOps
{% csrf_token %}記住密碼
后端代碼
def login(request): ret = {"status": False, "error": {"user_error": "", "pwd_error": "", "login_error": ""}} if request.method == "POST": user = request.POST.get("user") #獲取用戶(hù)名 pwd = request.POST.get("pwd") #獲取密碼 if request.META['REMOTE_ADDR']: #判斷是否獲取用戶(hù)IP地址 access_ip = request.META['REMOTE_ADDR'] #存到access_ip變量中 else: access_ip = request.META['HTTP_X_FORWARDED_FOR'] #獲取用戶(hù)的真實(shí)IP,非代理IP if access_ip: ip_obj = models.login_history.objects.filter(ip=access_ip).first() #在歷史登錄表中查找是否有這個(gè)IP if ip_obj: current_time = datetime.datetime.now() #獲取當(dāng)前時(shí)間 second = current_time - ip_obj.utime #用當(dāng)前時(shí)間減去最近登錄的時(shí)間 second = second.seconds #轉(zhuǎn)換為秒數(shù) count = ip_obj.count #獲取當(dāng)前對(duì)象的登錄次數(shù) count = count + 1 #次數(shù)加1 ip_obj.count = count #修改次數(shù)信息 ip_obj.save() #保存 if second < 60 and count >= 10: #判斷秒數(shù)是否小于60秒并且次數(shù)大于等于10 ret["error"]["login_error"] = "過(guò)于頻繁登錄,你已經(jīng)被鎖著,等一會(huì)60秒之后再登錄" ip_obj.user = user #登錄的用戶(hù)名 ip_obj.lock = 1 #值為1表示鎖著 ip_obj.save() #保存 return HttpResponse(json.dumps(ret)) #返回給前端 elif ip_obj.lock == 1 and second >= 60: #判斷l(xiāng)ock是否等于1和秒數(shù)大于60秒 ip_obj.lock = 0 #值為0表示解鎖 ip_obj.count = 1 #初始化登錄次數(shù) ip_obj.save() #保存 else: models.login_history.objects.create(user=user, ip=access_ip, count=1, lock=0) #沒(méi)有登錄過(guò),就創(chuàng)建記錄 if user: account_obj = Account.objects.filter(username=user).first() #判斷這個(gè)用戶(hù)名是否存在 if not account_obj: ret["error"]["user_error"] = "用戶(hù)名錯(cuò)誤或者不存在" else: ret["error"]["user_error"] = "用戶(hù)名不能為空" if pwd == "": ret["error"]["pwd_error"] = "密碼不能為空" users = authenticate(username=user, password=pwd) #驗(yàn)證用戶(hù)名和密碼是否一樣 if users: request.session["user_id"] = users.pk #存儲(chǔ)到session會(huì)話(huà)中 initial_session(users, request) ret["status"] = True ip_obj.count = 1 # 登錄次數(shù)等于1 ip_obj.save() return HttpResponse(json.dumps(ret)) #返回前端 else: ret["error"]["pwd_error"] = "用戶(hù)名或密碼不正確" return HttpResponse(json.dumps(ret)) return render(request, "login.html")
三、測(cè)試效果
1.不輸入賬號(hào)密碼登錄,會(huì)提示錯(cuò)誤信息
2.輸入不存在的用戶(hù)
3.輸入錯(cuò)誤密碼
4.在60秒內(nèi)連續(xù)輸錯(cuò)10次密碼,可以讓惡意登錄的,鎖著無(wú)法再讓其登錄
5.查看數(shù)據(jù)庫(kù)表信息
6.最后演示登錄成功跳轉(zhuǎn)圖
到此,關(guān)于“django實(shí)現(xiàn)賬號(hào)密碼驗(yàn)證登陸功能”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!