Django基础之Session版登录验证

from functools import wraps

def check_login(func):
    @wraps(func)
    def inner(request, *args, **kwargs):
        next_url = request.get_full_path()
        if request.session.get("user"):
            return func(request, *args, **Kwargs)
        else: 
            return redirect("/login/?next={}".format(next_url))
    return inner

def login(request):
    if request.method == "POST":
        username = request.POST.get("username")
        password = request.POST.get("password")
        
        if username == "yang" and password = "123":
            # 设置session
            request.session["user"] = user
            #获取跳到登录页面之前的URL
            next_url = request.GET.get("next")
            # 如果有,就跳转到登录之前的URL
            if next_url:
                return redirect(next_url)
            # 否则默认跳转到index页面
            else:
                return redirect("/index/")
    return render(request, "login.html")
    


@check_login
def logout(request):
    # 删除所有当前请求相关的session
    request.session.delete()
    return redirect("/login/")
    
@check_login
def index(request):
    current_user = request.session.get("user", None)
    return render(request, "index.html", {"user": currrent_user})

  

posted @ 2018-11-21 22:08  _杨魏  阅读(1139)  评论(0编辑  收藏  举报