0

私は Dingo Api と JWT Auth で Laravel 5.1.33 を使用しており、これらすべてをインストールしていますが、たとえばユーザーを認証したい場合にさらに多くのことを行う必要があるかどうか混乱しているため、ユーザーは特定のルートにアクセスできません。最初にログインされます。

私は api.php でこのコードを修正しました:

    'auth' => [
    'jwt' => 'Dingo\Api\Auth\Provider\JWT',
],

ここに来ると、このコードをどこに追加すればよいのか、実際には何をするのか混乱します。

app('Dingo\Api\Auth\Auth')->extend('jwt', function ($app) {
   return new Dingo\Api\Auth\Provider\JWT($app['Tymon\JWTAuth\JWTAuth']);
});

dingo/api には tymondesigns/jwt-auth のサポートが組み込まれていることを読みましたが、これは認証コードを記述する必要がないということですか? または、これはどういう意味ですか?

現時点で以下のように見える現在の AuthController を変更する必要があるかどうか、誰か教えてください。

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ThrottlesLogins;
use Illuminate\Foundation\Auth\AuthenticatesAndRegistersUsers;

class AuthController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Registration & Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users, as well as the
    | authentication of existing users. By default, this controller uses
    | a simple trait to add these behaviors. Why don't you explore it?
    |
    */

    use AuthenticatesAndRegistersUsers, ThrottlesLogins;

    /**
     * Create a new authentication controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest', ['except' => 'getLogout']);
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|confirmed|min:6',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        return User::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);
    }
}

もしそうなら、どのメソッドを追加する必要がありますか? Dingoは組み込みのjwt認証をサポートしていると書かれているため、このパッケージを使用することにしました。この理由だけでなく、トランスフォーマー、レート制限などの他の理由もいくつかあります...しかし、追加のコードを記述する必要があるかどうかはまだ混乱していますビルドで既にサポートされているため、認証ユーザーの場合...そうでない場合、どうすればログインできますか? 認証用にルートを宣言したり、ユーザーを登録したりしていません。何らかの方法でこれらのルートをいくつかのコントローラーに向ける必要があります。誰かがこれを手伝ってくれますか?

4

2 に答える 2

-1

このgithubプロジェクトを見てください。ルートとコントローラーを参照できます。

いくつかのメソッドを追加する必要があります。たとえば、

  1. login: トークンを取得するためのユーザー ログイン。
  2. リフレッシュ トークン: トークンが無効な場合。
于 2016-12-27T08:28:47.720 に答える