I'm getting "CSRF Failed: CSRF token missing or incorrect." error while doing a POST request to a django api from my localhost machine.
My service on 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())
}
My settings on 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
my 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)
and finally my login.component.html where i am sending to the username and password to the login function:
<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>
What am i missing here ?