login with captcha
This commit is contained in:
		
							parent
							
								
									98003e547b
								
							
						
					
					
						commit
						865579f8d2
					
				|  | @ -1,6 +1,7 @@ | ||||||
| from django import forms | from django import forms | ||||||
| 
 | from captcha.fields import CaptchaField | ||||||
| 
 | 
 | ||||||
| class GroupsForm(forms.Form): | class GroupsForm(forms.Form): | ||||||
|     username = forms.CharField(label="用户名", max_length=128, widget=forms.TextInput(attrs={'class': 'form-control', 'placeholder': "Username",'autofocus': ''})) |     username = forms.CharField(label="用户名", max_length=128, widget=forms.TextInput(attrs={'class': 'form-control', 'placeholder': "Username",'autofocus': ''})) | ||||||
|     password = forms.CharField(label="密码", max_length=256, widget=forms.PasswordInput(attrs={'class': 'form-control','placeholder': "Password"})) |     password = forms.CharField(label="密码", max_length=256, widget=forms.PasswordInput(attrs={'class': 'form-control','placeholder': "Password"})) | ||||||
|  |     captcha = CaptchaField(label='验证码', error_messages={"invalid":"验证码错误"}) | ||||||
|  |  | ||||||
|  | @ -15,7 +15,9 @@ | ||||||
|     <div class="container"> |     <div class="container"> | ||||||
|             <div class="col"> |             <div class="col"> | ||||||
|               <form class="form-login" action="/groups/login/" method="post"> |               <form class="form-login" action="/groups/login/" method="post"> | ||||||
|                   {% if message %} |                   {% if groups_form.captcha.errors %} | ||||||
|  |                         <div class="alert alert-warning">{{ groups_form.captcha.error_messages }}</div> | ||||||
|  |                   {% elif message %} | ||||||
|                         <div class="alert alert-warning">{{ message }}</div> |                         <div class="alert alert-warning">{{ message }}</div> | ||||||
|                   {% endif %} |                   {% endif %} | ||||||
|                   {% csrf_token %} |                   {% csrf_token %} | ||||||
|  | @ -28,6 +30,10 @@ | ||||||
|                   {{ groups_form.password.label_tag }} |                   {{ groups_form.password.label_tag }} | ||||||
|                   {{ groups_form.password }} |                   {{ groups_form.password }} | ||||||
|                 </div> |                 </div> | ||||||
|  |                   <div class="form-group"> | ||||||
|  |                     {{ groups_form.captcha.label_tag }} | ||||||
|  |                     {{ groups_form.captcha }} | ||||||
|  |                   </div> | ||||||
|                 <div> |                 <div> | ||||||
|                    <button type="submit" class="btn btn-primary float-right">登录</button> |                    <button type="submit" class="btn btn-primary float-right">登录</button> | ||||||
|                 </div> |                 </div> | ||||||
|  | @ -43,3 +49,12 @@ | ||||||
| 
 | 
 | ||||||
|   </body> |   </body> | ||||||
| </html> | </html> | ||||||
|  | <script> | ||||||
|  | $('.captcha').click(function () { | ||||||
|  | 
 | ||||||
|  |     $.getJSON("/groups/refresh_captcha/", function (result) { | ||||||
|  |         $('.captcha').attr('src', result['image_url']); | ||||||
|  |         $('#id_captcha_0').val(result['key']) | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | </script> | ||||||
|  | @ -1,4 +1,5 @@ | ||||||
| from django.urls import path | from django.urls import path | ||||||
|  | from django.urls import include | ||||||
| from . import views | from . import views | ||||||
| 
 | 
 | ||||||
| urlpatterns = [ | urlpatterns = [ | ||||||
|  | @ -6,5 +7,6 @@ urlpatterns = [ | ||||||
|     path('index/', views.index, name='index'), |     path('index/', views.index, name='index'), | ||||||
|     path('login/', views.login, name='login'), |     path('login/', views.login, name='login'), | ||||||
|     path('logout/', views.logout, name='logout'), |     path('logout/', views.logout, name='logout'), | ||||||
| 
 |     path('captcha/', include('captcha.urls')), | ||||||
|  |     path('refresh_captcha/', views.refresh_captcha), | ||||||
| ] | ] | ||||||
|  | @ -45,3 +45,14 @@ def logout(request): | ||||||
|         return redirect('/groups/login') |         return redirect('/groups/login') | ||||||
|     request.session.flush() |     request.session.flush() | ||||||
|     return redirect('/groups/login') |     return redirect('/groups/login') | ||||||
|  | 
 | ||||||
|  | import json | ||||||
|  | from captcha.models import CaptchaStore | ||||||
|  | from captcha.helpers import captcha_image_url | ||||||
|  | def refresh_captcha(request): | ||||||
|  |     hashkey = CaptchaStore.generate_key() | ||||||
|  |     image_url = captcha_image_url(hashkey) | ||||||
|  |     return HttpResponse(json.dumps({'key': hashkey, 'image_url': image_url}), content_type='application/json') | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | @ -39,6 +39,7 @@ INSTALLED_APPS = [ | ||||||
|     'django.contrib.staticfiles', |     'django.contrib.staticfiles', | ||||||
|     'safesite', |     'safesite', | ||||||
|     'groups', |     'groups', | ||||||
|  |     'captcha', | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| MIDDLEWARE = [ | MIDDLEWARE = [ | ||||||
|  |  | ||||||
|  | @ -0,0 +1,15 @@ | ||||||
|  | # Generated by Django 2.1.4 on 2019-10-09 09:52 | ||||||
|  | 
 | ||||||
|  | from django.db import migrations | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  | 
 | ||||||
|  |     dependencies = [ | ||||||
|  |         ('safesite', '0265_auto_20190917_1716'), | ||||||
|  |         ('safesite', '0267_auto_20190917_1543'), | ||||||
|  |         ('safesite', '0265_companyinfo'), | ||||||
|  |     ] | ||||||
|  | 
 | ||||||
|  |     operations = [ | ||||||
|  |     ] | ||||||
		Loading…
	
		Reference in New Issue