2

我想使用 Backbone.js 和 Django 构建单页应用程序。

检查用户是否通过身份验证,

我在 django 端写了一个方法 get_identity 方法。如果 request.user.is_authenticated 为 true 则返回 request.user.id 否则返回 Http404

在主干方面,我定义了一个用户模型并定期对 get_identity 进行 ajax 调用。

我认为这是检查用户是否经过身份验证的最直接方法。

对于学习单页应用来说,如果可能的话,我想做这个操作比这种方式更明智和高效。

那么您对此有何建议?当我搜索 Django+Backbone.js + User Authentication 时,我找不到任何令人满意的结果,我真的很想知道人们是如何做这个简单的操作的。

任何帮助或想法将不胜感激。

(顺便说一句,我尝试定期读取 cookie,但客户端无法访问 HttpOnly True 标记的 cookie。)

Django 视图.py

def get_identity(request):
    if not request.user.is_authenticated():
        raise Http404
    return HttpResponse(json.dumps({'identity':request.user.id}), mimetype="application/json")

Backbone.js 方面。

updateUser:function(){
            var $self=this;
            $.ajaxSetup({async:false});
            $.get(
                '/get_identity',
                function(response){
                    // update model...
                    $self.user.id =response.identity;
                    //check user every five minutes...
                     $self.user.fetch({success: function() {
                       $self.user.set('is_authenticated',true);
                       setTimeout($self.updateUser, 1000*60*1);
                        }
                    },this);
                }).fail(function(){
                    //clear model
                    $self.user.clear().set($self.user.defaults);
                    setTimeout($self.updateUser, 1000*60*1);
                });
            $.ajaxSetup({async:true});
        }
4

1 回答 1

6

var is_authenticated = {{request.user.is_authenticated}};在我的 base.html

并使用全局变量进行检查。

我正在寻求更好的解决方案(因为当您开始缓存时这会中断)。
但你可能会发现它很有用。

于 2015-02-22T04:02:26.963 回答