使用Laravel注册用户 - 未经身份验证的错误,但用户已添加到数据库

时间:2017-06-30 22:46:51

标签: php laravel authentication registration laravel-passport

我是Laravel的新手,我正在尝试为用户注册设置API。

我正在使用Auth / RegisterController和路由:

Route::post('register', 'Auth\RegisterController@register');

我的Auth / RegisterController:

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;

class RegisterController extends Controller
{
/*
|--------------------------------------------------------------------------
| Register Controller
|--------------------------------------------------------------------------
|
| This controller handles the registration of new users as well as their
| validation and creation. By default this controller uses a trait to
| provide this functionality without requiring any additional code.
|
*/

use RegistersUsers;

/**
 * Where to redirect users after registration.
 *
 * @var string
 */
protected $redirectTo = '/home';

/**
 * Create a new controller instance.
 *
 * @return void
 */
public function __construct()
{
    $this->middleware('guest');
}

/**
 * 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|string|max:255',
        'email' => 'required|string|email|max:255|unique:users',
        'password' => 'required|string|min:6|confirmed',
    ]);
}

/**
 * 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']),
    ]);
  }
}

此文件正在使用RegistersUsers:

<?php

namespace Illuminate\Foundation\Auth;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Auth\Events\Registered;

trait RegistersUsers
{
use RedirectsUsers;

/**
 * Show the application registration form.
 *
 * @return \Illuminate\Http\Response
 */
public function showRegistrationForm()
{
    return view('auth.register');
}

/**
 * Handle a registration request for the application.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return \Illuminate\Http\Response
 */
public function register(Request $request)
{
    $this->validator($request->all())->validate();

    event(new Registered($user = $this->create($request->all())));

    $this->guard()->login($user);

    return $this->registered($request, $user)
                    ?: redirect($this->redirectPath());
}

/**
 * Get the guard to be used during registration.
 *
 * @return \Illuminate\Contracts\Auth\StatefulGuard
 */
protected function guard()
{
    return Auth::guard();
}

/**
 * The user has been registered.
 *
 * @param  \Illuminate\Http\Request  $request
 * @param  mixed  $user
 * @return mixed
 */
  protected function registered(Request $request, $user)
  {
    //
  }
}

我只需要注意,当我将Auth添加到我的Laravel项目时,这些文件是自动生成的。我没有改变这些文件中的sny单行。

我的路线/ api.php文件:

<?php

use Illuminate\Http\Request;

/*
|--------------------------------------------------------------------------
| API Routes
|--------------------------------------------------------------------------
|
| Here is where you can register API routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| is assigned the "api" middleware group. Enjoy building your API!
|
*/

Route::middleware('auth:api')->get('/user', function (Request $request) {
    return $request->user();
});

Route::post('register', 'Auth\RegisterController@register');

当我尝试使用

注册用户时
api/register

我发送参数名称,电子邮件,密码和密码确认。

作为标题,我已设置:

Accept:application/json
Content-Type:application/x-www-form-urlencoded

我发送帖子请求并得到回复401(未经授权):

{
     "error": "Unauthenticated."
}

但是,用户保存在数据库中。当我尝试使用相同的数据再次发送此请求时,我得到响应422 - 不可处理的实体

{
     "email": 
     [
          "The email has already been taken."
     ]
}

如果我尝试删除

public function __construct()
{
    $this->middleware('guest');
}

它没有修复任何东西

我的问题是,如果响应应该是200 - 成功,为什么我会收到* 401(未授权)错误,因为用户已保存在数据库的用户表中?。提前谢谢。

0 个答案:

没有答案