如何解决使用 laravel 登录 drupal 7 网站
我一直在尝试使用来自 drupal 7 数据库的用户创建 Laravel 登录。由于 drupal 7 有自己的密码加密方法,laravel 自带的加密方法不起作用,因此每次尝试登录时总是返回身份验证失败。
{
$request->validate([
'mail' => 'required|string|email','pass' => 'required|string','remember_me' => 'boolean',]);
//dd(hash('sha256',$request->pass));
$credentials = request(['mail','pass']);
if (!Auth::attempt(['mail' =>$request->mail,'pass' => hash('sha256',$request->pass)])) {
return response()->json([
'message' => 'Unauthorized'],401);
}
$user = $request->user();
$tokenResult = $user->createtoken('Personal Access Token');
$token = $tokenResult->token;
if ($request->remember_me) {
$token->expires_at = Carbon::Now()->addWeeks(1);
}
$token->save();
$user->api_token = $tokenResult->accesstoken;
return response()->json($user);
}
我根本无权访问 drupal 项目。
我愿意接受任何想法。
解决方法
如果您导航到 drupal 目录中的 includes/password.inc
,您将找到一个名为:user_check_password 的函数。此方法可以帮助您根据散列密码验证纯文本密码。
因此,最简单的方法是将 laravel 连接到现有的 drupal 数据库并使用来自 drupal 的 password.inc 文件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。