59 lines
1.9 KiB
Python
59 lines
1.9 KiB
Python
|
from .main import AuthBaseHandler
|
|||
|
from .account import authenticate, add_user
|
|||
|
|
|||
|
class LoginHandler(AuthBaseHandler):
|
|||
|
def get(self,*args,**kwargs):
|
|||
|
self.render('login.html')
|
|||
|
|
|||
|
def post(self,*args,**kwargs):
|
|||
|
username = self.get_argument('username',None)
|
|||
|
password = self.get_argument('password',None)
|
|||
|
|
|||
|
# check the password
|
|||
|
passed = authenticate(username,password)
|
|||
|
|
|||
|
if passed:
|
|||
|
# 保存cookie信息到redis数据库
|
|||
|
self.session.set('username',username) #将前面设置的cookie设置为username,保存用户登录信息
|
|||
|
print(self.session.get('username'))
|
|||
|
next_url = self.get_argument('next', '') # 获取之前页面的路由
|
|||
|
if next_url:
|
|||
|
self.redirect(next_url) #跳转主页路由
|
|||
|
else:
|
|||
|
self.redirect('/')
|
|||
|
else:
|
|||
|
self.write({'msg':'login fail'}) #不通过,有问题
|
|||
|
|
|||
|
|
|||
|
|
|||
|
class LogoutHandler(AuthBaseHandler):
|
|||
|
def get(self, *args, **kwargs):
|
|||
|
#self.session.set('username','') #将用户的cookie清除
|
|||
|
self.session.delete('username')
|
|||
|
self.redirect('/login')
|
|||
|
|
|||
|
# def post(self,*args,**kwargs):
|
|||
|
# self.session.delete('username')
|
|||
|
# self.redirect('/login')
|
|||
|
|
|||
|
class RegisterHandler(AuthBaseHandler):
|
|||
|
def get(self, *args, **kwargs):
|
|||
|
print('register')
|
|||
|
self.render('register.html')
|
|||
|
|
|||
|
def post(self, *args, **kwargs):
|
|||
|
print('registerpost')
|
|||
|
|
|||
|
username = self.get_argument('username','')
|
|||
|
password1 = self.get_argument('password1','')
|
|||
|
password2 = self.get_argument('password2','')
|
|||
|
|
|||
|
if username and password1 and (password1 == password2):
|
|||
|
success = add_user(username,password1)
|
|||
|
if success:
|
|||
|
self.redirect('/login')
|
|||
|
else:
|
|||
|
self.write({'msg':'register fail'})
|
|||
|
else:
|
|||
|
print('register again')
|
|||
|
self.render('register.html')
|