繁体   English   中英

Laravel 5.5如何修改登录过程以使用现有的db用户表(SQL Server)

[英]Laravel 5.5 how to modify login process to use existant db User Table (SQL Server)

我是Laravel的初学者。 对不起任何愚蠢的问题。 我的情况如下:在Sql Server中有一个带有用户表的先前数据库。 该表称为USUARIO_EMITENTE。 该表具有一个名为“ user”的键字段和一个使用md5的“ password”字段(这不是我的错,它已经存在了)。 因此,为了使用此表,我更改了用户模型,如下所示:

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Notifiable;

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'user', 'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];

    protected $table = 'Usuario_Emitente';
}

我的loginController是默认的(使用laravel 5.5):

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;

class LoginController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles authenticating users for the application and
    | redirecting them to your home screen. The controller uses a trait
    | to conveniently provide its functionality to your applications.
    |
    */

    use AuthenticatesUsers;

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

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

现在,我必须将LoginController更改为:1)获取字段“用户”,而不是laravel Auth的默认电子邮件; 2)使用md5代替bcrypt; 3)登录后重定向到/ menu

我是否需要更改任何其他班级吗?

有人可以帮助我吗?

此登录过程需要做些事情-设置表单数据名称,为登录表单设置路由,以及将路由映射到进行哈希和重定向/验证检查的逻辑。 (您也可以添加服务器验证和错误消息)。

(1)当您提交Auth表单时,您将使用名称用户并说通过,

(2)在routes.php中,将POST身份验证URL路由到LoginController(新方法)loginUser:

Route::post('/login', 'LoginController@loginUser');

(3)向您的loginUser()函数添加逻辑,以处理密码,字段数据和重定向(理论上,您还希望运行验证并在此处检查输入)。 注意:根据一个社区,不建议在bcrypt上使用md5 ,但是可以手动完成( 如何使用md5代替bcrypt? )!

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;

class LoginController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles authenticating users for the application and
    | redirecting them to your home screen. The controller uses a trait
    | to conveniently provide its functionality to your applications.
    |
    */

    use AuthenticatesUsers;

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

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

    public function loginUser()
    {
        // $data = \Request::all();
        $user = \Request::input(‘user’);
        $pass = \Request::input(‘pass’);

        if ( !isset($user) || !isset($pass) ) {
            // Bad Creds. No access!
            return redirect('/loginPage');
        } else {

            $user = User::where('user', $user)->where('password', md5($pass))->first();

            if ($user) {
            Auth::login($user);
            return redirect()->intended('/');
            } else {/* No User Found? */}

        }
    }

}

(4)根据上述同一篇文章,还必须为MD5创建一个新的Service Provider,以便在LoginController类中使用。 这使您可以像上面那样使用“ md5(…)”。 但是,由于另一个用户回答了这个问题,因此我将保留链接供您跟踪以了解他的所作所为。

希望这可以帮助。

参考

在Laravel5.5中通过bcrypt的md5

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM