I want to let a user sign in before seeing pages. Is there any built-in template for user sign in, so that I do not have to write my own sign in page?
from django.contrib.auth import authenticate, login def my_view(request): username = request.POST['username'] password = request.POST['password'] user = authenticate(request, username=username, password=password) if user is not None: login(request, user) # Redirect to a success page. ... else: # Return an 'invalid ...
To configure the Django template system, go to the settings.py file and update the DIRS to the path of the templates folder. Generally, the templates folder is created and kept in the sample directory where manage.py lives. This templates folder contains all the templates you will create in different Django Apps.
As mentioned in the comments by the author, the easiest way to do this is to add the following lines to urls.py:
from django.contrib.auth.views import login, logout urlpatterns = patterns('', url(r'^accounts/login/$', login, {'template_name': 'admin/login.html'}), url(r'^accounts/logout/$', logout), ) As far as I know, adding the r'^accounts/$' and r'^accounts/profile/$' URLs is not necessary unless user profile management is required.
As suggested by @mmatt in comments, set LOGIN_REDIRECT_URL = '/' in settings.py to avoid the default redirect to /accounts/profile/ after login. See LOGIN_REDIRECT_URL in Django settings documentation.
This should also still work in Django 2.x using path instead of url appropriately.
Yes. You can read all about it here: https://docs.djangoproject.com/en/1.8/topics/auth/default/#django.contrib.auth.decorators.login_required ... but here are some bullet points:
'django.contrib.auth.middleware.AuthenticationMiddleware' to MIDDLEWARE_CLASSES in settings.py 'django.contrib.auth' and 'django.contrib.contenttypes' to INSTALLED_APPS in settings.py django.contrib.auth.views.login for the view, such as url(r'^login/$', 'django.contrib.auth.views.login',name="my_login") views.py...
from django.contrib.auth.decorators import login_required @login_required def home(request): return HttpResponse('Home Page') By default, you then put the template inside my_template_directory/registration/login.html . Further info about that template can be found at the link in the beginning of this post.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With