上一篇中,我们用最简单的方法实现了登陆,但是真实的开发中肯定不现实,我们需要使用session来保存我们需要的数据,并在需要的时候显示在页面上。
我们的登陆代码变成了:
def checkuser(request):
if request.method == 'POST':
user = request.POST.get('username')
passwd = request.POST.get('password')
print user,passwd
try:
passwd_db = User.objects.get(username=user).password
except:
messages.add_message(request,messages.WARNING,'找不到用户')
return render(request, 'showdb/login.html',{'login_info_list':"请使用正确的账号密码登陆"},)
if passwd == passwd_db :
request.session['username'] = user
request.session.set_expiry(600)
return render(request, 'showdb/index.html',{
'welcome':"欢迎你"})
else:
messages.add_message(request,messages.WARNING,'密码错误')
return render(request, 'showdb/login.html',{'login_info_list':"请使用正确的账号密码登陆"},)
语句是request.session['username'] = user,将user保存在session中。下面的set_expiry方法是设置session的过期时间,为600s。
然后我们在页面中添加:
{% if request.session.username %}
<h4 style='font-family:楷体;'>{{ welcome}} {{ request.session.username }} </h4>
{% else %}
<h3 style='font-family:楷体;'>请重新登陆</h3>
{% endif %}
这样的话,就能把用户名展示出来了。
效果如下: