python注册登录修改密码退出_django 框架实现的用户注册、登录、退出功能示例...

本文实例讲述了django 框架实现的用户注册、登录、退出功能。分享给大家供大家参考,具体如下:

1 用户注册:

from django.contrib import auth

from django.contrib.auth.models import User

from django.views.decorators.csrf import csrf_exempt

from django.http import HttpResponseRedirect

# 用户注册

@csrf_exempt

def register(request):

errors = []

account = None

password = None

password2 = None

email = None

CompareFlag = False

if request.method == 'POST':

if not request.POST.get('account'):

errors.append('用户名不能为空')

else:

account = request.POST.get('account')

if not request.POST.get('password'):

errors.append('密码不能为空')

else:

password = request.POST.get('password')

if not request.POST.get('password2'):

errors.append('确认密码不能为空')

else:

password2 = request.POST.get('password2')

if not request.POST.get('email'):

errors.append('邮箱不能为空')

else:

email = request.POST.get('email')

if password is not None:

if password == password2:

CompareFlag = True

else:

errors.append('两次输入密码不一致')

if account is not None and password is not None and password2 is not None and email is not None and CompareFlag :

user = User.objects.create_user(account,email,password)

user.save()

userlogin = auth.authenticate(username = account,password = password)

auth.login(request,userlogin)

return HttpResponseRedirect('/blog')

return render(request,'blog/register.html', {'errors': errors})

2 用户登录:

@csrf_exempt

def my_login(request):

errors =[]

account = None

password = None

if request.method == "POST":

if not request.POST.get('account'):

errors.append('用户名不能为空')

else:

account = request.POST.get('account')

if not request.POST.get('password'):

errors = request.POST.get('密码不能为空')

else:

password = request.POST.get('password')

if account is not None and password is not None:

user = auth.authenticate(username=account,password=password)

if user is not None:

if user.is_active:

auth.login(request,user)

return HttpResponseRedirect('/blog')

else:

errors.append('用户名错误')

else:

errors.append('用户名或密码错误')

return render(request,'blog/login.html', {'errors': errors})

3 用户退出:

def my_logout(request):

auth.logout(request)

return HttpResponseRedirect('/blog')

URL:

urlpatterns = [

url(r'^$', views.index, name='index'),

url(r'^p/(?P[0-9]+)/$', views.detail,name='detail'),

url(r'^register/$',views.register, name='register'),

url(r'^login/$',views.my_login, name='my_login'),

url(r'^logout/$',views.my_logout, name='my_logout'),

]

注册 HTML:

Title

{% if errors %}

{% for error in errors %}

{{error}}

{% endfor %}

{% endif %}

用户名:

密码:

确认密码:

邮箱:

登录HTML:

Title登录

{% if errors %}

{% for error in errors %}

{{error}}

{% endfor %}

{% endif %}

用户名:

密码:

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值