0

Passport認証を使用した新しいlaravelアプリケーションがあります。ログイン用のコードは、不眠症アプリケーションで完全に機能します。

ログイン:

public function login(Request $request)
{
   if(Auth::attempt(['username' => request('username'), 'password' => request('password')]))
   { 
      $user = Auth::user(); 
      $success['token'] =  $user->createToken('AppName')-> accessToken; 
      return response()->json(['authstat'=>'Authorized','user'=>Auth::user()->id,'access_token'=>$success]); 
   } 
   else
   { 
      return response()->json(['authstat'=>'Unauthorized']); 
   } 
}

不眠症テスト

http://api-auth.test/api/auth/login

//json request 
{
    "username":"wen",
    "password":"12345678"
}

しかし、ブラウザで試してみるとUnauthorized、正しいユーザー名とパスワードを渡しても常に返されます。これがフロントエンドからの私の ajax リクエストです。

<script type="text/javascript">
        
    $("#loginfrm").on("submit", function(e){
        event.preventDefault();
        var username = $("#username").val();
        var password = $("#password").val();
        
        $.ajax({
            type: "POST",
            url: "http://api-auth.test/api/auth/login",
            contentType: "application/json",
            Accept: "application/json",
            dataType: 'json',
            data:{
                "_token": "{{ csrf_token() }}",
                "username": username,
                "password": password
            },
            complete: function (data) {
                console.log(data.responseJSON["authstat"]);
            }
        });
    });
      
</script>

助言がありますか?ありがとう。

4

1 に答える 1