Backbone.js 和 Django Rest Framework 注册和身份验证

Backbone.js and Django Rest Framework registration and authentication

本文关键字:注册 身份验证 Framework Django js Backbone Rest      更新时间:2023-09-26

我正在使用 backbone.js 为我的前端创建一个应用程序,为我的后端创建 django-rest-framework。我希望能够注册用户,登录和注销用户,并检查用户是否使用主干登录。

我了解 django 身份验证的工作原理以及 drf 如何使用身份验证,但我不知道如何将它绑定到骨干中。

谁能指出我正确的方向?

如果你的所有应用程序只能通过用户密码访问,请使用 Django 的身份验证系统 https://docs.djangoproject.com/en/1.7/topics/auth/default/#django.contrib.auth.views.login。将您的所有视图@login_required。

现在,如果要通过 ajax 调用登录它们,请创建一个视图,如下所示:

from django.contrib.auth import authenticate
from django.views.decorators.csrf import csrf_exempt
@csrf_exempt
def login_ajax(request):
    data = json.loads(request.body.decode("utf-8"))
    user = authenticate(username=data['user'], password=data['pass'])
    if user:      
        return HttpResponse("OK")
    else:
        return HttpResponse("Error", status=401)

稍后,在模板上的 JS 上:

$.post( /* url where you mapped the login_ajax view */, { user: "John", pass: "abc123" } )
 .done(function( data ) { alert( "User logged in: " + data );})
 .fail(function( data ) { alert( "User not logged in: " + data );});

我正在使用 django-rest-auth 和 AngularJS。它为您提供了一组 REST API 端点来处理用户注册和身份验证任务,并与 django-rest-framework 和 django-allauth 完美集成。

要获取用户信息,您需要调用此 API:

.../rest-auth/user/

默认情况下,响应为:

username
first_name
last_name
email

但是您可以使用其他信息对其进行扩展。