我得到" CSRF失败:CSRF令牌丢失或不正确。"从我的localhost机器向django api发出POST请求时出错。
我在Angular2上的服务:
public login(user: any){
const body = JSON.stringify(user);
const headers = new Headers();
headers.append('Content-Type', 'application/json');
return this.http.post("http://127.0.0.1:8000/auth_api/login/", body, {
headers: headers
})
.map((data: Response) => data.json())
}
我在Django上的设置:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'corsheaders',
'scrumboard',
'auth_api'
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'corsheaders.middleware.CorsMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
CORS_ORIGIN_ALLOW_ALL = True
我的LoginView API:
class LoginView(views.APIView):
@csrf_exempt
def post(self, request):
user = authenticate(
username=request.data.get("username"),
password=request.data.get("password"))
if user is None or not user.is_active:
return Response({
'status': 'Unauthorized',
'message': 'Email or password incorrect'
}, status=status.HTTP_401_UNAUTHORIZED)
login(request, user)
return Response(UserSerializer(user).data)
最后我的login.component.html我将发送到登录功能的用户名和密码:
<div class="card-block">
<h1>Login</h1>
<p class="text-muted">Sign In to your account</p>
<form [formGroup]="myForm" (ngSubmit)="onSignin(username.value, password.value)">
<div class="input-group mb-1">
<span class="input-group-addon"><i class="icon-user"></i></span>
<input formControlName="username" type="text" id="username" class="form-control" placeholder="username" #username>
</div>
<div class="input-group mb-2">
<span class="input-group-addon"><i class="icon-lock"></i></span>
<input formControlName="password" type="password" class="form-control" placeholder="Password" #password>
</div>
<div class="row">
<div class="col-6">
<button type="submit" [disabled]="!myForm.valid" class="btn btn-primary px-2">Login</button>
</div>
</div>
</form>
</div>
我在这里缺少什么?
答案 0 :(得分:0)
可能不是问题,但密码是如何在您的登录功能中发送的?
尝试在{% csrf_token %}
标记下方添加<form...
。
如果CSRF引入跨网站请求伪造漏洞,我会毫不犹豫地制作。
这是我在注册页面上运行的一些代码。
<form class="form-horizontal" method="post" style="align: center">
{% csrf_token %}
{{ reg_form.non_field_errors }}
...
答案 1 :(得分:0)
如果您尚未与API服务器进行过互动,则可能无法在您登录的时间点设置CSRF令牌。
您想要修饰post方法,以便它不需要令牌,然后只检查令牌以响应实际返回数据的其他后续POST请求...
from django.views.decorators.csrf import csrf_exempt
@method_decorator(csrf_exempt, name='dispatch')
class LoginView(views.APIView):
def post(self, request):
...