使用Django自带的登录访问限制login_required

在网站开发过程中,经常会遇到这样的需求:

  • 用户登陆系统才可以访问某些页面

  • 如果用户没有登陆而直接访问就会跳转到登陆界面,

  • 用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地

完成这样的功能其实不难,最简单的一种方法即为使用django自带的登录访问限制login_required。其使用方法非常简单,只需要在视图函数views.py中引入(login_required是一个装饰器)并装饰(所有)需要进行登录访问限制的视图函数即可,详情如下:

#views.py
...

from djanco.contrib.auth.decorators import login_required

@login_required             # 例子比较简单
def  myview(request):
     return  render_to_response( 'index.html' )    # 假设其对应路由为/index/
                                                                                                              

#settings.py
....
LOGIN_URL  =  '/login/'   #这个路径需要根据你网站的实际登陆地址来设置,也就是登录路由
....
                                                                                                                 

以上做好以后,没有登录的情况下直接访问/index/路由(本地为127.0.0.1:8000/index/)会发现出现类似下面的界面

使用Django自带的登录访问限制login_required_第1张图片


说明以上代码生效了,然后大家看路由地址发现有了参数?next=/index/登录成功后就会跳转路由到/index/。

如果说以上都执行后发现并没有跳转到next指向的路由,此时要注意了,注意做以下操作:

    此时我们的登录路由/login/有了参数next=/.../,我们只需要在登录的视图函数中获取到这个参数并在能获取到该next参数时重定向到next指向的路由即可,例如:

                                                                                                                                        

#views.py      在登录的视图函数逻辑中修改
def userlogin (request):
   next_to = request.GET.get('next', false)
   if request.user:       #判断用户是否登录成功
       if next_to:
       return HttpResponseRedirect( next_to )

    return render_to_response('index.html')    # 跳转到首页         

                                                                                                                                                      

如果是其它的路由/detail/等等操作都是一样的,三步走  1.挂视图(装饰器)2.设路由(登录路由)3.截跳转(获取到next就重定向)

你可能感兴趣的:(django)