Laravel 5.3在注册后获得最后一个插入ID

时间:2018-05-10 11:37:06

标签: php ajax laravel laravel-5.3

使用laravel5.3 php 5.6.3

我想在注册后的重定向页面的users表中输入最后一个id

所以我希望最后插入的id为userprofileadd.blade.php

我也试过了 - > with('id',$ user-> id)来自寄存器功能

我不想在注册后自动登录,所以我删除了登录部分,注册后用户将被重定向到另一个表单,我想要用户表中的最新用户ID(谁曾注册)

注册控制器:

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\role;
use App\Userdetails;

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 = '/userprofileadd';

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

    /**
     * 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, [

            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|min:6|confirmed',
            'role'=>'required'
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        return User::create([

            'email' => $data['email'],
            'password' => bcrypt($data['password']),
            'role_id'=>$data['role'],
        ]);
    }

    public function showregistrationform()
    {
        $roles = role::all(); // get all teams
    return view('auth.register', [ 'roles' => $roles]);
    }
}

注册功能(注册后我已注释掉登录)

 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());
            // ->with('id', $user->id)
    }

2 个答案:

答案 0 :(得分:2)

如果您使用的是模型

$user = new User();
$user->name = "JOHN";
$user->save();
$user->id; // contain the inserted id

如果您使用的是db class

$id = DB::table('users')->insertGetId(
   ['email' => 'john@example.com', 'votes' => 0]
);

答案 1 :(得分:1)

我不确定这是否是你要找的,但你可以这样做来检索用户表中的最新记录:

$latestUser = App\User::latest()->first();

希望这有帮助。